当前位置: 首页 > 图文教程 > 网络编程 > PHP > PHP文件上传的原理及实现

PHP
PHP 5.0对象模型深度探索之访问方式
解决phpMyAdmin2.6以上版本数据乱码问题
PHP开发中session应用详解
Lore Article.PHP SQL注入漏洞
Mysql存取session实例
php调用mysql存储过程和函数的方法
用PHP5进行三层开发
在PHP中进行GB2312与UTF-8的互换
php与XML、XSLT、Mysql的结合运用,代码篇
php与XML、XSLT、Mysql的结合运用,安装篇
用GD图库生成横竖柱状图折线图的类
一个全面获取图象信息的函数getImageInfo()
用PHP与XML联手进行网站编程
PHPMailer:Featured email transfer class for PHP
php用流方式制作缩略图
php+odbc+access数据库操作函数,在windows下测试通过
PHP IPwhois类
用PHP读写NTFS文件系统下的文件摘要信息
一个简单上传文件出错的解决
PHP实现自动刷数和“灌水”机

PHP文件上传的原理及实现


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 132 ::
收藏到网摘: n/a

利用php的文件函数来实现上传

这段代码分为两个文件,一个为upload.html,一个是upload.php

以下为引用的内容:

upload.html
<form enctype="multipart/form-data" action="upload.php" method="post">
<input type="hidden" name="max_file_size" value="100000">
<input name="userfile" type="file">  
<input type="submit" value="上传文件">
</form>


 其中,

请注意<form enctype="multipart/form-data"......>这是一个标签,我们要实现文件的上传,必须指定为multipart/form-data,否则服务器将不知道要干什么。

值得注意的是文件upload.html中表单选项 MAX_FILE_SIZE 的隐藏值域,通过设置其Value(值)可以限制上载文件的大小。

MAX_FILE_SIZE 的值只是对浏览器的一个建议,实际上它可以被简单的绕过。因此不要把对浏览器的限制寄希望于该值。实际上,PHP 设置中的上传文件最大值,是不会失效的。但是最好还是在表单中加上 MAX_FILE_SIZE,因为它可以避免用户在花时间等待上传大文件之后才发现该文件太大了的麻烦。

以下为引用的内容:

upload.php
$f=&$HTTP_POST_FILES['Myfile'];
$dest_dir='uploads';//设定上传目录
$dest=$dest_dir.'/'.date("ymd")."_".$f['name'];//设置文件名为日期加上文件名避免重复
$r=move_uploaded_file($f['tmp_name'],$dest);
chmod($dest, 0755);//设定上传的文件的属性

或者

以下为引用的内容:

 <?copy($_FILES[MyFile][tmp_name],$_FILES[MyFile][name]);?>
以上范例中 $_FILES 数组的内容如下所示。我们假设文件上传字段的名称为 userfile(名称可随意命名)

$_FILES['userfile']['name'] 客户端机器文件的原名称。
$_FILES['userfile']['type'] 文件的 MIME 类型,需要浏览器提供该信息的支持,例如“image/gif”。
$_FILES['userfile']['size'] 已上传文件的大小,单位为字节。
$_FILES['userfile']['tmp_name'] 文件被上传后在服务端储存的临时文件名。
$_FILES['userfile']['error'] 和该文件上传相关的错误代码
值:0; 没有错误发生,文件上传成功。
值:1; 上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值。
值:2; 上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。
值:3; 文件只有部分被上传。
值:4; 没有文件被上传。