设为首页 收藏本站
查看: 447|回复: 0

[经验分享] php上传文件详解

[复制链接]

尚未签到

发表于 2017-3-24 10:01:40 | 显示全部楼层 |阅读模式
上传文件功能由两个部分组成,HTML页面和PHP处理部分。HTML页面主要是让用户选择所要上传的文件,php部分让我们可以把文件存储到服务器的指定目录。
一.HTML部分
  upload.html

[html]
view plaincopyprint?





  • <html>

  • <head>

  • <metacontent="text/html;charset=utf-8"http-equiv="Content-Type">

  • </head>

  • <body>
  • 上传Demo:

  • <formaction="upload.php"method="post"enctype="multipart/form-data">

  • <inputtype="file"name="img"/>

  • <inputtype="submit"name="submit"value="上传"/>

  • </form>

  • </body>

  • </html>



<html>
<head>
<meta content="text/html; charset=utf-8" http-equiv="Content-Type">
</head>
<body>
上传Demo:
<form action="upload.php" method="post" enctype="multipart/form-data">
<input type="file" name="img" />
<input type="submit" name="submit" value="上传" />
</form>
</body>
</html>
  说明:
1.Input标签中type="file"表明把输入作为文件来处理。
2.Enctype规定了在提交这个表单时要使用哪种内容类型。在表单需要二进制数据时,比如文件内容,请使用"multipart/form-data",如果要上传文件,这个属性是必要的。
更多关于enctype的内容参见《HTML <form> 标签的
enctype 属性》


二.php部分

upload.php

[php]
view plaincopyprint?





  • <?php

  • $DST_DIR='/data/upload/';

  • if($_FILES['img']['name']!=''){

  • if($_FILES['img']['error']>0){

  • echo"上传失败";
  • }

  • else{

  • if(move_uploaded_file($_FILES['img']['tmp_name'],$DST_DIR.$_FILES['img']['name'])){

  • echo"上传成功";
  • }

  • else{

  • echo"上传失败";
  • }
  • }
  • }

  • else{

  • echo"请上传文件";
  • }



<?php
$DST_DIR = '/data/upload/';
if ($_FILES['img']['name'] != '') {
if ($_FILES['img']['error'] > 0) {
echo "上传失败";
}
else {
if (move_uploaded_file($_FILES['img']['tmp_name'], $DST_DIR.$_FILES['img']['name'])) {
echo "上传成功";
}
else {
echo "上传失败";
}
}
}
else {
echo "请上传文件";
}

  说明:
1.全局变量$_FILE
此数组包含有所有上传的文件信息。

以我们假设文件上传字段的名称如上例所示,为img。则
$_FILES['img']['name']
客户端上传的文件的原名称。
$_FILES['img']['type']
文件的MIME类型,如果浏览器提供此信息的话。一个例子是“image/gif”。不过此MIME类型在PHP端并不检查,因此不要想当然认为有这个值。$_FILES['img']['size']:已上传文件的大小,单位为字节。
$_FILES['img']['size']
已上传文件的大小,单位为字节。
$_FILES['img']['tmp_name']
文件被上传后在服务端储存的临时文件名。
$_FILES['img']['error']
和该文件上传相关的错误代码。

2.关于错误码
$_FILES['img']['error']有以下几种类型
UPLOAD_ERR_OK
其值为0,没有错误发生,文件上传成功。
UPLOAD_ERR_INI_SIZE
其值为1,上传的文件超过了php.iniupload_max_filesize选项限制的值。
UPLOAD_ERR_FORM_SIZE
其值为2,上传文件的大小超过了HTML表单中MAX_FILE_SIZE选项指定的值。
UPLOAD_ERR_PARTIAL
其值为3,文件只有部分被上传。
UPLOAD_ERR_NO_FILE
其值为4,没有文件被上传。
UPLOAD_ERR_NO_TMP_DIR
其值为6,找不到临时文件夹。PHP4.3.10PHP5.0.3引进。
UPLOAD_ERR_CANT_WRITE
其值为7,文件写入失败。PHP5.1.0引进。

3.move_uploaded_file
文件被上传后,默认地会被储存到服务端的默认临时目录中(除非php.ini中的upload_tmp_dir设置为其它的路径),文件名是随机的。如果该文件没有被移动到其它地方也没有被改名,则该文件将在表单请求结束时被删除。因此需要通过move_uploaded_file移动临时文件。

经实验copy也能完成move_uploaded_file的功能,为啥要用move_uploaded_file呢?有说法是move_uploaded_file会对上传文件做一些检查,防止copy引起的一些安全漏洞。但具体copy会带来什么问题呢?我并没有查到。有知道的同学,欢迎留言。

Anyway,既然php给了特定的函数,必然有一定道理,先这么用吧。
  
三.安全检查

可以考虑通过$_FILES['img']['size']和$_FILES['img']['type']对上传的文件做一些安全检查,比如限定上传类型,上传文件的大小等。


  附:
《与文件上传有关的php配置参数》







转自:http://blog.csdn.net/qmhball/article/details/7841912




上传文件功能由两个部分组成,HTML页面和PHP处理部分。HTML页面主要是让用户选择所要上传的文件,php部分让我们可以把文件存储到服务器的指定目录。
一.HTML部分
  upload.html

[html]
view plaincopyprint?





  • <html>

  • <head>

  • <metacontent="text/html;charset=utf-8"http-equiv="Content-Type">

  • </head>

  • <body>
  • 上传Demo:

  • <formaction="upload.php"method="post"enctype="multipart/form-data">

  • <inputtype="file"name="img"/>

  • <inputtype="submit"name="submit"value="上传"/>

  • </form>

  • </body>

  • </html>



<html>
<head>
<meta content="text/html; charset=utf-8" http-equiv="Content-Type">
</head>
<body>
上传Demo:
<form action="upload.php" method="post" enctype="multipart/form-data">
<input type="file" name="img" />
<input type="submit" name="submit" value="上传" />
</form>
</body>
</html>
  说明:
1.Input标签中type="file"表明把输入作为文件来处理。
2.Enctype规定了在提交这个表单时要使用哪种内容类型。在表单需要二进制数据时,比如文件内容,请使用"multipart/form-data",如果要上传文件,这个属性是必要的。
更多关于enctype的内容参见《HTML <form> 标签的
enctype 属性》


二.php部分

upload.php

[php]
view plaincopyprint?





  • <?php

  • $DST_DIR='/data/upload/';

  • if($_FILES['img']['name']!=''){

  • if($_FILES['img']['error']>0){

  • echo"上传失败";
  • }

  • else{

  • if(move_uploaded_file($_FILES['img']['tmp_name'],$DST_DIR.$_FILES['img']['name'])){

  • echo"上传成功";
  • }

  • else{

  • echo"上传失败";
  • }
  • }
  • }

  • else{

  • echo"请上传文件";
  • }



<?php
$DST_DIR = '/data/upload/';
if ($_FILES['img']['name'] != '') {
if ($_FILES['img']['error'] > 0) {
echo "上传失败";
}
else {
if (move_uploaded_file($_FILES['img']['tmp_name'], $DST_DIR.$_FILES['img']['name'])) {
echo "上传成功";
}
else {
echo "上传失败";
}
}
}
else {
echo "请上传文件";
}

  说明:
1.全局变量$_FILE
此数组包含有所有上传的文件信息。

以我们假设文件上传字段的名称如上例所示,为img。则
$_FILES['img']['name']
客户端上传的文件的原名称。
$_FILES['img']['type']
文件的MIME类型,如果浏览器提供此信息的话。一个例子是“image/gif”。不过此MIME类型在PHP端并不检查,因此不要想当然认为有这个值。$_FILES['img']['size']:已上传文件的大小,单位为字节。
$_FILES['img']['size']
已上传文件的大小,单位为字节。
$_FILES['img']['tmp_name']
文件被上传后在服务端储存的临时文件名。
$_FILES['img']['error']
和该文件上传相关的错误代码。

2.关于错误码
$_FILES['img']['error']有以下几种类型
UPLOAD_ERR_OK
其值为0,没有错误发生,文件上传成功。
UPLOAD_ERR_INI_SIZE
其值为1,上传的文件超过了php.iniupload_max_filesize选项限制的值。
UPLOAD_ERR_FORM_SIZE
其值为2,上传文件的大小超过了HTML表单中MAX_FILE_SIZE选项指定的值。
UPLOAD_ERR_PARTIAL
其值为3,文件只有部分被上传。
UPLOAD_ERR_NO_FILE
其值为4,没有文件被上传。
UPLOAD_ERR_NO_TMP_DIR
其值为6,找不到临时文件夹。PHP4.3.10PHP5.0.3引进。
UPLOAD_ERR_CANT_WRITE
其值为7,文件写入失败。PHP5.1.0引进。

3.move_uploaded_file
文件被上传后,默认地会被储存到服务端的默认临时目录中(除非php.ini中的upload_tmp_dir设置为其它的路径),文件名是随机的。如果该文件没有被移动到其它地方也没有被改名,则该文件将在表单请求结束时被删除。因此需要通过move_uploaded_file移动临时文件。

经实验copy也能完成move_uploaded_file的功能,为啥要用move_uploaded_file呢?有说法是move_uploaded_file会对上传文件做一些检查,防止copy引起的一些安全漏洞。但具体copy会带来什么问题呢?我并没有查到。有知道的同学,欢迎留言。

Anyway,既然php给了特定的函数,必然有一定道理,先这么用吧。
  
三.安全检查

可以考虑通过$_FILES['img']['size']和$_FILES['img']['type']对上传的文件做一些安全检查,比如限定上传类型,上传文件的大小等。


  附:
《与文件上传有关的php配置参数》







转自:http://blog.csdn.net/qmhball/article/details/7841912

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-354461-1-1.html 上篇帖子: php header定义页面编码 下篇帖子: PHP 性能优化技巧
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表