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

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

以下是代码

index.PHP

rush:PHP;"> <a href="https://www.jb51.cc/tag/PHP/" target="_blank" class="keywords">PHP</a>实现<a href="https://www.jb51.cc/tag/tupian/" target="_blank" class="keywords">图片</a>的<a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a>和验证
上传功能
PHP" method="post" enctype="multipart/form-data"> 上传图片上传">
序号PHP //1 打开目录 $dir=opendir("./uploads"); //2 遍历目录,输出里面的图片 $i=0; while($f=readdir($dir)){ $i++; //读取目录中的文件,模拟数据库操作 if($f!="." && $f!=".."){ $filename="./uploads/$f"; echo "查看

upload.PHP

rush:PHP;"> 0){ echo $_FILES['pic']['error']; echo "上传文件错误!"; echo '<Meta http-equiv="refresh" content="3;url=index.PHP">'; //自动跳转回index文件 }else{ //开始获取上传文件的信息 $file=$_FILES['pic']; //var_dump($file);打印文件里的全部信息 //name:上传文件名 //type:上传文件的类型 //tmp_name:上传成功后的临时文件 //size:上传文件的大小 //error:上传文件错误信息 $uploaddir="./uploads/"; //选择要上传文件存放目录 //$uploadfile=$uploaddir.basename($file['name']);//获得上传文件名称 //解析文件的名字 $fileinfo=pathinfo($file['name']); // echo $fileinfo['extension']; 获取文件的类型 do{ $newfile=date("YmdHis").rand(1000,9999).".".$fileinfo['extension'];//更改文件的名字,获取一个新的名字 }while(file_exists($uploaddir.$newfile));
  //<a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a><a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>的类型限制
  if (!(($file['type'] == "image/gif")||($file['type'] == "image/jpeg")||($file['type'] == "image/pjpeg"))){
    die("<a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>类型<a href="https://www.jb51.cc/tag/cuowu/" target="_blank" class="keywords">错误</a>!");
    echo '<meta http-equiv="refresh" content="3;url=index.php"&gt;';
  }
  //上传文件的大小限制
  if($file['size'] > 2*1024*1024){
    die("<a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a><a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>超过2MB!");
    echo '<<a href="https://www.jb51.cc/tag/Meta/" target="_blank" class="keywords">Meta</a> http-equiv="refresh" content="3;url=index.<a href="https://www.jb51.cc/tag/PHP/" target="_blank" class="keywords">PHP</a>"&gt;';
  }
  //开始<a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a><a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>
  if (is_uploaded_file($file['tmp_name'])) {
    if (move_uploaded_file($file['tmp_name'],$uploaddir.$newfile)) {
      echo "<a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a>成功!";
      echo '<<a href="https://www.jb51.cc/tag/Meta/" target="_blank" class="keywords">Meta</a> http-equiv="refresh" content="3;url=index.<a href="https://www.jb51.cc/tag/PHP/" target="_blank" class="keywords">PHP</a>"&gt;';//<a href="https://www.jb51.cc/tag/zidongtiaozhuan/" target="_blank" class="keywords">自动跳转</a>回index<a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>
    } else {
      echo "<a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a>失败,请稍等!";
      echo '<meta http-equiv="refresh" content="3;url=index.php"&gt;'; //自动跳转回index文件
    }
  }

}

?>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...
图片 添加时间 操作