对于php编程来说,PEAR可以说是一个软件库,下面本人就试用使用HTTP_Upload来处理文件上传。在上一节的基础之上,我们使用了$_FILES这个全局全量来处理通过表单上传的文件,但是对于这个常用的编程操作,我们是否有更加强大的方式呢?比如在文件上传的过程中,所发生的错误,我们是否可以使用统一的方式来显示从而更加人性化呢?我们是否可以使用面向对象的特性来封装这些处理细节从而让代码更加的简洁和易于理解呢?这一切就交给HTTP_Upload吧?
安装HTTP_Upload
HTTP_Upload是PEAR中的一个库,所以我们要使用HTTP_Upload,就得安装它:
请参阅安装phpDocumentor的方法在安装了pear之后,我们可以使用以下的方法来安装HTTP_Upload:
在执行pear install HTTP_Upload后,我们应该可以顺利的成功!查看安装结果:pear list,如图:

添加路径:
在php.ini中查找include_path,添加到php的搜索路径中,如图:

重启apache,这样你的HTTP_Upload就可以正确的被包含进来,不会在require(’HTTP/Upload.php’)时出错。
下面就来看看,它的功能吧,如下代码所示:
我们唯一使用的就是getFiles(’file’)中的file,这个file就是表单中的name:<input type=”file” name=”file” id=”file” />,一切就是这样的简单。如果你要使用HTTP_Upload上传多个文件,可以new多个对象然后像上面这样处理就可以了。
关于HTTP_Upload的中方法,请自己查看它的源代码。文件位置:PEAR\HTTP。
众所周知,文件上传在一些网站应用中是必不可少的一部分。比如个人博客上传个性头像,一些论坛分享好的学习资料等,这就涉及到使用表单处理文件上传的知识,在php中我们可以使用$_FILES这个全局数组来处理。下面就看看基本的文件上传处理部分。首先要说明的,能够上传文件必定是一个安全隐患,所以在开发这部分功能时,一定要注意网站的安全性。而本文所探讨的只是基本的文件上传部分,关于安全性这方面考虑的较少,希望在日后的高级应用中可以学习的到。
在PHP预定义变量这一节我们对一些预定义变量进行了一些大概的学习,其中就有$_FILES这个全局变量,那么现在再来详细的了解关于这个全局量的知识,因为我在处理文件上传时,要使用到它的相关功能。
$_FILES参数详解:
$_FILES["file"]["name"] – 被上传文件的名称
$_FILES["file"]["type"] – 被上传文件的类型
$_FILES["file"]["size"] – 被上传文件的大小,以字节计
$_FILES["file"]["tmp_name"] – 存储在服务器的文件的临时副本的名称
$_FILES["file"]["error"] – 由文件上传导致的错误代码
$_FILES["file"]["error"]中的["error"]值情况:
UPLOAD_ERR_OK
0:没有错误发生,文件上传成功
UPLOAD_ERR_INI_SIZE
1:上传的文件超过了 php.ini中upload_max_filesize(默认情况为2M) 选项限制的值
UPLOAD_ERR_FORM_SIZE
2:上传文件的大小超过了 HTML表单中MAX_FILE_SIZE选项指定的值
UPLOAD_ERR_PARTIAL
3:文件只有部分被上传
UPLOAD_ERR_NO_FILE
4:没有文件被上传
5:传文件大小为0
下面我们就来看看最基本的文件上传:
这个HTML页面如下图:
upload-file.php代码如下:
我们随便上传一个word文件,看看处理结果如何:
可以看到,这个文件被保存到C:\WINDOWS\temp\临时目录下,你可能想去看看在这个目录是否存在这个文件,但结果是:没有!为什么呢?因为php在执行完这个脚本后,把它生成的文件又删除了,所以在上传之后还要进一步处理。另外还随便提一下,在windows下,php所生成的临时文件如php7D.tmp是有规律的,也就是说在下一次通过表单上传的文件应该像这样:php7E.tmp
为了保存我们上传的文件,要使用move_uploaded_file函数。在你的upload-file.php文件同目录创建一个upload文件夹。下面再来看看上面那个示例:
?>
再来看看结果:
经过这一步的处理,在我们所指定的地方(upload)就可以得到我们上传的文件。到这里,最基本的文件上传就结束了。还说一下,我们在上传的时候一定要考虑文件的类型,要考虑文件的大小等。关于这些方面随着学习的深入再来介绍吧。
如果你是一个学习php的新手,请查看php教程文章归档。