今天研究了一下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
<?php header("Content-Type:text/html;charset=utf-8"); ?> <title>PHP实现图片的上传和验证</title> <style> table{text-align:center;} </style> <div align="center"> <h1>上传功能</h1> <form action="index_ok.php" method="post" enctype="multipart/form-data"> 上传图片:<input type="file" name="pic"> <input type="submit" name="sub" value="上传"> </form> <table width="500"> <tr bgcolor="#cccccc"> <th>序号</th> <th>图片</th> <th>添加时间</th> <th>操作</th> </tr> <?php //1 打开目录 $dir=opendir("./uploads"); //2 遍历目录,输出里面的图片 $i=0; while($f=readdir($dir)){ $i++; //读取目录中的文件,模拟数据库操作 if($f!="." && $f!=".."){ $filename="./uploads/$f"; echo "<tr>"; echo "<td>{$i}</td>"; echo "<td><img src='./uploads/{$f}' width='80' height='60'></td>"; echo "<td>".date("Y-m-d",filectime($filename))."</td>"; echo "<td><a href='./uploads/{$f}'>查看</a></td>"; echo "</tr>"; } } //3 关闭目录 closedir($dir); ?> <tr bgcolor="#cccccc"><td colspan="4"> </td></tr> </table> </div>
upload.php
<?php header("Content-Type:text/html;charset=utf-8"); if($_FILES['pic']['error']>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)); //上传文件的类型限制 if (!(($file['type'] == "image/gif")||($file['type'] == "image/jpeg")||($file['type'] == "image/pjpeg"))){ die("文件类型错误!"); echo '<meta http-equiv="refresh" content="3;url=index.php">'; } //上传文件的大小限制 if($file['size'] > 2*1024*1024){ die("上传文件超过2MB!"); echo '<meta http-equiv="refresh" content="3;url=index.php">'; } //开始上传文件 if (is_uploaded_file($file['tmp_name'])) { if (move_uploaded_file($file['tmp_name'], $uploaddir.$newfile)) { echo "上传成功!"; echo '<meta http-equiv="refresh" content="3;url=index.php">';//自动跳转回index文件 } else { echo "上传失败,请稍等!"; echo '<meta http-equiv="refresh" content="3;url=index.php">'; //自动跳转回index文件 } } } ?>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍jQuery实现本地预览上传图片功能,包括了jQuery实现本地预览上传图片功能的使用技巧和注意事项,需要的朋友参考一下 本文实例介绍了基于JQUERY扩展,图片上传预览插件,目前兼容浏览器(IE 谷歌 火狐) 不支持safari,分享给大家供大家参考,具体内容如下 HTML代码: js代码: 直接上第二段代码,jquery js实现上传图片之前预览本地图片 以上就是本文的全部内容,
本文向大家介绍php用wangeditor3实现图片上传功能,包括了php用wangeditor3实现图片上传功能的使用技巧和注意事项,需要的朋友参考一下 就在最近,公司让我写一个后台,其中用到了富文本编辑器。自从这个富文本的出现 我就慢慢的进入了一个坑,起初不知道用什么编辑器好,看了好多好多,最后选择了。这个 wangeditor3。个人认为这个富文本很干净,还很多功能。 选择了编辑器 我就慢慢
本文向大家介绍php实现图片上传、剪切功能,包括了php实现图片上传、剪切功能的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家详细介绍了php实现图片上传、剪切功能的具体代码,供大家参考,具体内容如下 以上就是本文的全部内容,希望对大家学习php程序设计有所帮助。
本文向大家介绍vue+elementUI实现表单和图片上传及验证功能示例,包括了vue+elementUI实现表单和图片上传及验证功能示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了vue+elementUI实现表单和图片上传及验证功能。分享给大家供大家参考,具体如下: 最终实现需求如下图: form表单内容与重点人员图片同时上传且图片为必填项 分析弹框页需要解决的问题有: 1、表单内
本文向大家介绍PHP实现多图上传和单图上传功能,包括了PHP实现多图上传和单图上传功能的使用技巧和注意事项,需要的朋友参考一下 下面一段代码给大家介绍php实现单图上传和多图上传的功能,具体代码如下所示: 总结 以上所述是小编给大家介绍的PHP实现多图上传和单图上传功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对呐喊教程网站的支持!
本文向大家介绍Django Admin实现上传图片校验功能,包括了Django Admin实现上传图片校验功能的使用技巧和注意事项,需要的朋友参考一下 Django 为未来的开发人员提供了许多功能:一个成熟的标准库,一个活跃的用户社区,以及 Python 语言的所有好处。虽然其他 Web 框架也声称能提供同样的内容,但 Django 的独特之处在于它内置了管理应用程序 —— admin。 adm