PHP实现本地图片的上传和验证功能

By | 2017年 2月 9日

今天研究了一下PHP的FILES函数,使用PHP实现本地图片的上传,验证文件是否为图片,并将图片保存在指定目录下,实现游览图片的功能,感觉还是很好玩的,一共有两个PHP页面,一个作为前台的上传和图片展示,另一个用来处理保存图片,代码里做了很详细的注释,并将FILES函数的语法,error报错类型写了出来,还有一些注意事项。

FILES函数

  1. $_FILES['myFile']['name'] 客户端文件的原名称
  2. $_FILES['myFile']['type'] 文件的 MIME类型,需要浏览器提供该信息的支持,例如"image/gif"
  3. $_FILES['myFile']['size'] 已上传文件的大小,单位为字节
  4. $_FILES['myFile']['tmp_name'] 文件被上传后在服务端储存的临时文件名,一般是系统默认,可以在php.ini的upload_tmp_dir指定

关于FILES中error报错类型及其注意:

过滤错误号

  • 0: 没有错误发生,文件上传成功
  • 1: 上传的文件超过了 php.ini 中 upload_max_filesize选项限制的值
  • 2: 上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值
  • 3: 文件只有部分被上传
  • 4: 没有文件被上传
  • 5: 上传文件大小为0

注意:

  1. 文件被上传结束后,默认地被存储在了临时目录中,这时必须将它从临时目录中删除或移动到其它地方,如果没有,则会被删除。也就是不管是否上传成功,脚本执行完后临时目录里的文件肯定会被删除。所以在删除之前要用PHP的copy() 函数将它复制到其它位置,此时,才算完成了上传文件过程。
  2. 在 PHP 4.1.0 版本以前该数组的名称为$HTTP_POST_FILES,它并不像$_FILES 一样是自动全局变量。PHP 3 不支持$HTTP_POST_FILES数组。
  3. 用form上传文件时,一定要加上属性内容enctype="multipart/form-data",否则用$_FILES[filename]获取文件信息时会报异常。

效果如下图

以下是代码

index.php

upload.php

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注