PHP文件上传功能代码实例教程

网络整理 - 08-06

在PHP网站开发中,PHP程序如何实现文件上传功能,一直是新手的课题。而且文件上传功能一般都用得着,比如图片上传。今天就结合具体代码实例和详细注解和大家分享如何编写PHP文件上传代码,适合php初学者学习。

  PHP代码实例主要讲述的是图片上传,看懂程序后你可以修改相关文件类型就可以实现其他文件的上传功能。

编程环境

  PHP5.2.4,基本上PHP4.3以上版本,此代码都可以使用

准备工作

  检查upload_tmp_dir项

  如果PHP的开发环境是自行搭建的,你需要在编写文件上传程序前编辑php.ini文件,找到并编辑upload_tmp_dir选项,此项用来设定文件上传至服务器时的临时文件夹,比如upload_tmp_dir = E:/phpos/uploads,然后再重启Apache。如果PHP的开发环境使用的是傻瓜式一键安装包,一般upload_tmp_dir都是设定好了的,你也可以用phpinfo()函数查看下配置。

  编写一个upload文件,设定文件上传表单

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

  注意

  1、表单中enctype=”multipart/form-data”必须指定,以便让服务器知道文件带有常规的表单信息。

  2、必须有一个可以设置上传文件最大长度的表单区域,即允许上传文件的最大值(按字节计算),它是隐藏值域,即max_file_size,通过设置其Value(值)可以限制上传文件的大小,避免用户在花时间等待上传大文件之后才发现该文件太大了的麻烦。但是一般别人可以绕过这个值,所以安全起见,最好是在php.ini文件中配置upload_max_filesize选项,设定文件上传的大小,默认是2M。

文件上传程序

 
function uploadfile($type,$name,$ext,$size,$error,$tmp_name,$targetname,$upload_dir)
{
    $MAX_SIZE=2000000;
    $FILE_MIMES=array('image/pjpeg','image/jpeg','image/jpg','image/gif','image/png');
    $FILE_EXTS=array('.jpg','.gif','.png','.JPG','.GIF','.PNG');

    $file_path=$upload_dir.$targetname;
  
    if(!is_dir($upload_dir))
    {
        if(!mkdir($upload_dir))
            die("文件上传目录不存在并且无法创建文件上传目录");
        if(!chmod($upload_dir,0755))
            die("文件上传目录的权限无法设定为可读可写");
    }
  
    if($size>$MAX_SIZE)
        die("上传的文件大小超过了规定大小");

    if($size==0)
        die("请选择上传的文件");

    if(!in_array($type,$FILE_MIMES)||!in_array($ext,$FILE_EXTS))
        die("请上传符合要求的文件类型");

    if(!move_uploaded_file($tmp_name,$file_path))
        die("复制文件失败,请重新上传");

    switch($error)
    {
        case0:
            return;
        case1:
            die("上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值");
        case2:
            die("上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值");
        case3:
            die("文件只有部分被上传");
        case4:
            die("没有文件被上传");
    }
}

参数说明
$type,$name,$size,$error,$tmp_name对应全局变量$_FILES中的相关变量,即:
$_FILES['userfile']['type']:文件的MIME类型,需要浏览器提供该信息的支持,例如图片类型“image/gif”。

$_FILES['userfile']['name']:客户端文件的原名称。

$_FILES['userfile']['size']:已上传文件的大小,单位为字节。

$_FILES['userfile']['tmp_name']:文件被上传后在服务端储存的临时文件名。

$_FILES['userfile']['error']:和该文件上传相关的错误代码,即

值:0:没有错误发生,文件上传成功。

值:1:上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值。

值:2:上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。

值:3:文件只有部分被上传。

值:4:没有文件被上传。

$ext:上传文件扩展名

$targetname:文件上传后的最终文件名

$upload_dir:上传至哪个目录下,采用的是相对路径

注释:

第3行~第6行:设定图片文件上传的大小,以及文件的MIME类型以及扩展名,由于此代码为图片文件上传程序,所以两个数组中罗列了所有的图片类型,比如PNG,GIF,JEPG等。

第17行~第24行:如果文件是空的,size等于0;如果图片文件的扩展名或者类型不符,则跳出。

第26行:move_uploaded_file函数的功能是将upload_tmp_dir设定的服务端临时目录中的文件移至由$file_path指定的文件,注意如果目标文件已存在则覆盖目标文件

如何上传多个文件?比如同时上传3个文件

只需将

 
<inputname="userfile"type="file">

改成

 
<inputname="userfile[]"type="file">
<inputname="userfile[]"type="file">
<inputname="userfile[]"type="file">

对应的在调用此函数时,$_FILES['userfile']['name'][0],代表第一个文件的相关文件信息,依此类推,其他也一样。

总结

  此函数是PHP文件上传中最简单的核心代码,图片上传只是其中一种,只需要修改或者扩充$FILE_MIMES和$FILE_EXTS数组的相关信息,即可实现其他类型的文件上传功能。在函数的外围,根据自己的需要编写相关的其他代码即可实现其他功能,比如和数据库的关联等。