PHP 图片文件上传实现代码


Posted in PHP onDecember 29, 2010

为了网站的安全,肯定不让上传php文件,如果有人进入你的后台,上传了一个php文件,你的网站源码,全部救变成他的了,直接打包看你的代码。所以一定要控制上传的目录与文件类型,一般只可以上传图片。

创建一个文件上传表单
允许用户从表单上传文件是非常有用的。
请看下面这个供上传文件的 HTML 表单:

<html> 
<body> 
<form action="upload_file.php" method="post" 
enctype="multipart/form-data"> 
<label for="file">Filename:</label> 
<input type="file" name="file" id="file" /> 
<br /> 
<input type="submit" name="submit" value="Submit" /> 
</form> 
</body> 
</html>

请留意如下有关此表单的信息:
<form> 标签的 enctype 属性规定了在提交表单时要使用哪种内容类型。在表单需要二进制数据时,比如文件内容,请使用 "multipart/form-data"。
<input> 标签的 type="file" 属性规定了应该把输入作为文件来处理。举例来说,当在浏览器中预览时,会看到输入框旁边有一个浏览按钮。
注释:允许用户上传文件是一个巨大的安全风险。请仅仅允许可信的用户执行文件上传操作。
创建上传脚本
"upload_file.php" 文件含有供上传文件的代码:
<?php 
if ($_FILES["file"]["error"] > 0) 
{ 
echo "Error: " . $_FILES["file"]["error"] . "<br />"; 
} 
else 
{ 
echo "Upload: " . $_FILES["file"]["name"] . "<br />"; 
echo "Type: " . $_FILES["file"]["type"] . "<br />"; 
echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />"; 
echo "Stored in: " . $_FILES["file"]["tmp_name"]; 
} 
?>

通过使用 PHP 的全局数组 $_FILES,你可以从客户计算机向远程服务器上传文件。
第一个参数是表单的 input name,第二个下标可以是 "name", "type", "size", "tmp_name" 或 "error"。就像这样:
$_FILES["file"]["name"] - 被上传文件的名称 
$_FILES["file"]["type"] - 被上传文件的类型 
$_FILES["file"]["size"] - 被上传文件的大小,以字节计 
$_FILES["file"]["tmp_name"] - 存储在服务器的文件的临时副本的名称 
$_FILES["file"]["error"] - 由文件上传导致的错误代码

这是一种非常简单文件上传方式。基于安全方面的考虑,您应当增加有关什么用户有权上传文件的限制。
上传限制
在这个脚本中,我们增加了对文件上传的限制。用户只能上传 .gif 或 .jpeg 文件,文件大小必须小于 20 kb:
<?php 
if ((($_FILES["file"]["type"] == "image/gif") 
|| ($_FILES["file"]["type"] == "image/jpeg") 
|| ($_FILES["file"]["type"] == "image/pjpeg")) 
&& ($_FILES["file"]["size"] < 20000)) 
{ 
if ($_FILES["file"]["error"] > 0) 
{ 
echo "Error: " . $_FILES["file"]["error"] . "<br />"; 
} 
else 
{ 
echo "Upload: " . $_FILES["file"]["name"] . "<br />"; 
echo "Type: " . $_FILES["file"]["type"] . "<br />"; 
echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />"; 
echo "Stored in: " . $_FILES["file"]["tmp_name"]; 
} 
} 
else 
{ 
echo "Invalid file"; 
} 
?>

注释:对于 IE,识别 jpg 文件的类型必须是 pjpeg,对于 FireFox,必须是 jpeg。
保存被上传的文件
上面的例子在服务器的 PHP 临时文件夹创建了一个被上传文件的临时副本。
这个临时的复制文件会在脚本结束时消失。要保存被上传的文件,我们需要把它拷贝到另外的位置:
<?php 
if ((($_FILES["file"]["type"] == "image/gif") 
|| ($_FILES["file"]["type"] == "image/jpeg") 
|| ($_FILES["file"]["type"] == "image/pjpeg")) 
&& ($_FILES["file"]["size"] < 20000)) 
{ 
if ($_FILES["file"]["error"] > 0) 
{ 
echo "Return Code: " . $_FILES["file"]["error"] . "<br />"; 
} 
else 
{ 
echo "Upload: " . $_FILES["file"]["name"] . "<br />"; 
echo "Type: " . $_FILES["file"]["type"] . "<br />"; 
echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />"; 
echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br />"; 
if (file_exists("upload/" . $_FILES["file"]["name"])) 
{ 
echo $_FILES["file"]["name"] . " already exists. "; 
} 
else 
{ 
move_uploaded_file($_FILES["file"]["tmp_name"], 
"upload/" . $_FILES["file"]["name"]); 
echo "Stored in: " . "upload/" . $_FILES["file"]["name"]; 
} 
} 
} 
else 
{ 
echo "Invalid file"; 
} 
?>

上面的脚本检测了是否已存在此文件,如果不存在,则把文件拷贝到指定的文件夹。
注释:这个例子把文件保存到了名为 "upload" 的新文件夹。
PHP 相关文章推荐
初学者入门:细述PHP4的核心Zend
Sep 05 PHP
用PHP写的MySQL数据库用户认证系统代码
Mar 22 PHP
php URL跳转代码 减少外链
Jun 25 PHP
PHP正则表达式之定界符和原子介绍
Oct 05 PHP
PHP 登录记住密码实现思路
May 07 PHP
PHP实现数字补零功能的2个函数介绍
May 12 PHP
smarty缓存用法分析
Dec 16 PHP
PHP将二维数组某一个字段相同的数组合并起来的方法
Feb 26 PHP
php $_SESSION会员登录实例分享
Jan 19 PHP
详解php中空字符串和0之间的关系
Oct 23 PHP
PHP中Notice错误常见解决方法
Apr 28 PHP
PHP检测一个数组有没有定义的方法步骤
Jul 20 PHP
php目录操作函数之获取目录与文件的类型
Dec 29 #PHP
php下获取Discuz论坛登录用户名、用户组、用户ID等信息的实现代码
Dec 29 #PHP
上传文件先创建目录 再上传到目录里面去
Dec 29 #PHP
php输出表格的实现代码(修正版)
Dec 29 #PHP
纯php打造的tab选项卡效果代码(不用js)
Dec 29 #PHP
PHP的autoload自动加载机制使用说明
Dec 28 #PHP
php的ajax框架xajax入门与试用介绍
Dec 19 #PHP
You might like
虫族 ZERG 概述
2020/03/14 星际争霸
几款免费开源的不用数据库的php的cms
2010/12/19 PHP
第五章 php数组操作
2011/12/30 PHP
使用gd库实现php服务端图片裁剪和生成缩略图功能分享
2013/12/25 PHP
codeigniter实现get分页的方法
2015/07/10 PHP
使用CSS3实现字体颜色渐变的实现
2021/03/09 HTML / CSS
javascript Ext JS 状态默认存储时间
2009/02/15 Javascript
用JavaScript显示随机图像或引用
2009/04/21 Javascript
浅谈Javascript鼠标和滚轮事件
2012/06/27 Javascript
DIV始终居中的js代码
2014/02/17 Javascript
谈谈我对JavaScript原型和闭包系列理解(随手笔记8)
2015/12/24 Javascript
JavaScript如何实现跨域请求
2016/08/05 Javascript
jQuery webuploader分片上传大文件
2016/11/07 Javascript
JavaScript组成、引入、输出、运算符基础知识讲解
2016/12/08 Javascript
详解javascript常用工具类的封装
2018/01/30 Javascript
vue-router二级导航切换路由及高亮显示的实现方法
2019/07/10 Javascript
layui之table checkbox初始化时选中对应选项的方法
2019/09/02 Javascript
通过实例了解JS执行上下文运行原理
2020/06/17 Javascript
javascript中call,apply,bind的区别详解
2020/12/11 Javascript
[05:41]2014DOTA2西雅图国际邀请赛 小组赛7月10日TOPPLAY
2014/07/10 DOTA
Python版的文曲星猜数字游戏代码
2013/09/02 Python
python实现的登陆Discuz!论坛通用代码分享
2014/07/11 Python
python将字典内容存入mysql实例代码
2018/01/18 Python
Python实现微信小程序支付功能
2019/07/25 Python
Python PyPDF2模块安装使用解析
2020/01/19 Python
Django Admin后台模型列表页面如何添加自定义操作按钮
2020/11/11 Python
使用python将微信image下.dat文件解密为.png的方法
2020/11/30 Python
写给老婆的检讨书
2014/02/21 职场文书
外语系大学生自荐信范文
2014/03/01 职场文书
文化宣传方案
2014/03/13 职场文书
小学作文评语大全
2014/04/21 职场文书
羽毛球社团活动总结
2014/06/27 职场文书
2014年房地产工作总结范文
2014/11/19 职场文书
《清澈的湖水》教学反思
2016/02/17 职场文书
tensorboard 可视化之localhost:6006不显示的解决方案
2021/05/22 Python
JavaWeb Servlet开发注册页面实例
2022/04/11 Java/Android