【PHP】php文件上传和下载

本文详细介绍了PHP配置文件中与上传文件相关的选项设置,上传表单的注意事项,以及如何使用PHP处理上传的数据,包括错误检查、大小限制、类型限制、文件名改名和文件保存。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、文件上传
 *
 * 1. 单个文件上传
 *
 * 2. 多个文件上传
 *
 * 一、PHP配置文件中和上传文件有关的选项
 *  
 *     file_uploads = on 
 *
 *     upload_max_filesize= 200M  最大不要超过服务器的内存
 *
 *     upload_tmp_dir = c:/uploads/
 *
 *      post_max_size = 250M此项应大于upload_max_filesize
 *
 *     二、上传表单需要的注意事项
 *
 *    1. 如果有文件上传操作表单的提交方法必须 HTTP post 
 *    2. 表单上传需要使用type为file的表
 *    3. enctype="multipart/form-data" 只有文件上传时才使用这个值 ,用来指定表单编码的数据方式, 让服务器知道,我们要传递一个文件并带有常规的  *        表单信息。
 *
 * 4. 建议添加一个 MAX_FILE_SIZE 隐藏表单, 值的单位也是字节
 *
 *
 *    三、PHP处理上传的数据
 *
 *     
 *      $_POST 接收非上传的数据
 *
 *
 *    如果是文件上传的数据则使用 $_FILES处理上传的文件
 *
  [pic] => Array
        (
            [name] => hee.jpg
            [type] => image/pjpeg
            [tmp_name] => C:\WINDOWS\Temp\php68.tmp
            [error] => 0
            [size] => 24485
    )


Array
(
    [pic] => Array
        (
            [name] => Array
                (
                    [0] => icon_pdf.gif
                    [1] => icon_ppt.gif
                    [2] => icon_pptx.gif
                    [3] => icon_doc.gif
                )


            [type] => Array
                (
                    [0] => image/gif
                    [1] => image/gif
                    [2] => image/gif
                    [3] => image/gif
                )


            [tmp_name] => Array
                (
                    [0] => C:\WINDOWS\Temp\php69.tmp
                    [1] => C:\WINDOWS\Temp\php6A.tmp
                    [2] => C:\WINDOWS\Temp\php6B.tmp
                    [3] => C:\WINDOWS\Temp\php6C.tmp
                )


            [error] => Array
                (
                    [0] => 0
                    [1] => 0
                    [2] => 0
                    [3] => 0
                )


            [size] => Array
                (
                    [0] => 251
                    [1] => 205
                    [2] => 608
                    [3] => 281
                )


        )


)

2、

[php] view plaincopy

  1. <?php  
  2.     //step 1 使用$_FILES['pic']["error"] 检查错误  
  3.   
  4.     if($_FILES["pic"]["error"] > 0){  
  5.         switch($_FILES["pic"]["error"]) {  
  6.             case 1:  
  7.                 echo "上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值<br>";  
  8.                 break;  
  9.             case 2:  
  10.                 echo "上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值";  
  11.                 break;  
  12.   
  13.             case 3:   
  14.                 echo "文件只有部分被上传";  
  15.                 break;  
  16.   
  17.             case 4:  
  18.                 echo "没有文件被上传";  
  19.                 break;  
  20.   
  21.             default:  
  22.   
  23.                 echo "末知错误";  
  24.           
  25.         }  
  26.           
  27.         exit;  
  28.     }  
  29.       
  30.   
  31.     $maxsize=5000000;  //50k  
  32.   
  33.     //step 2 使用$_FILES["pic"]["size"] 限制大小 单位字节 2M=2000000  
  34.     if($_FILES["pic"]["size"] > $maxsize ) {  
  35.         echo "上传的文件太大,不能超过{$maxsize}字节";  
  36.         exit;  
  37.     }  
  38.   
  39.   
  40.     //step 3 使用$_FILES["pic"]["type"]或是文件的扩展名 限制类型 MIME  image/gif  image/png    gif png jpg  
  41.   
  42.     /*   list($dl, $xl) = explode("/", $_FILES["pic"]["type"]); 
  43.  
  44.         if($dl!="image"){ 
  45.             echo "请上传一个图片,不充许其它类型文件"; 
  46.             exit; 
  47.         } 
  48.      */  
  49.       
  50.     $allowtype=array("png""gif""jpg""jpeg");  
  51.   
  52.   
  53.     $arr=explode("."$_FILES["pic"]["name"]);  
  54.   
  55.     $hz=$arr[count($arr)-1];  
  56.   
  57.     if(!in_array($hz$allowtype)){  
  58.         echo "这是不充许的类型";  
  59.         exit;  
  60.     }  
  61.       
  62.   
  63.       
  64.     //step 4 将让传后的文件名改名  
  65.   
  66.       
  67.     $filepath="./uploads/";  
  68.   
  69.     $randname=date("Y").date("m").date("d").date("H").date("i").date("s").rand(100, 999).".".$hz;  
  70.   
  71.     //将临时位置的文件移动到指定的目录上即可  
  72.   
  73.     if(is_uploaded_file($_FILES["pic"]["tmp_name"])){  
  74.         if(move_uploaded_file($_FILES["pic"]["tmp_name"], $filepath.$randname)){  
  75.             echo "上传成功";  
  76.         }else{  
  77.             echo "上传失败";  
  78.         }  
  79.     }else{  
  80.         echo "不是一个上传文件";  
  81.     }  

 

3、

[php] view plaincopy

  1. <?php  
  2.     /*   请求 
  3.      *   1. HTTP 1.1  协议 版本 
  4.      *   2. 头信息,  
  5.      *   3. 你请求的表单信息, 你提交给服务器的信息 
  6.      * 
  7.      *   http://localhost/one.php?aa=bbb&ccc=ddd 
  8.      * 
  9.      *   响应 
  10.      *   1. 状态 200 ok   404 页面没找到 
  11.      *   2. 响应头信息,  
  12.      *   3. 数据发送给 
  13.      * 
  14.      */   
  15. ?>  

 

4、

[php] view plaincopy

  1. <?php  
  2.       
  3.     header("Content-Type:image/gif");  
  4.     header('Content-Disposition: attachment; filename="logo3333.gif"');  
  5.     header('Content-Length:'.filesize("logo.gif"));  
  6.     readfile("logo.gif");  
  7.       
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值