PHP文件上传和下载

内容整理自网上!

一、$_FILES预定义变量解析

name:上传文件的名称
type:上传文件的MIME类型
tmp_name:上传到服务器上的临时文件名
size:上传文件的大小
error:上传文件的错误号

二、服务端配置

file_uploads = On
upload_tmp_dir =”临时文件保存目录”
upload_max_filesize = 2M 允许文件上传的最大值
max_file_uploads = 20 允许一次上传的最大文件数
post_max_size = 8M POST方式发送数据的最大值
max_execution_time = 120 设置了脚本被解析器终止之前允许的最大执行时间,单位为秒,防止程序写得不好而占尽服务器资源
max_input_time = 60 脚本解析输入数据允许的最大时间,单位是秒
max_input_nesting_level = 64 设置输入变量的嵌套深度
内存限制:
max_input_vars = 2500 接受多少输入的变量(限制分别应用于 GET _POST、和$_COOKIE超全局变量)指令的使用减轻了以哈希碰撞来进行拒绝服务攻击的可能性。如有超过指定指令数量的变量。将会导致E_WANING的产生,更多的输入变量将会从请求中截断。
memory_limit = 128M 最大单线程的独立内存使用量,也就是一个web请求,给予线程最大的内存使用量的定义。

三、客户端限制

这里写图片描述
客户端限制可以轻易更改,没什么作用!

四、错误信息说明

UPLOAD_ERR_OK:其值为0,没有错误发生,文件上传成功
UPLOAD_ERR_INI_SIZE:其值为1.上传文件超过了php.ini中upload_max_filesize选项限制的值
UPLOAD_ERR_FROM_SIZE:其值为2,上传文件的大小超过了HTML表单中MAX_FILE_SIZE选项指定的值
UPLOAD_ERR_PARTIAL:其值为3,文件只有部分被上传
UPLOAD_ERR_NO_FILE:其值为4,没有文件被上传
UPLOAD_ERR_NO_TMP_DIR:其值为6,找不到临时文件夹
UPLOAD_ERR_CANT_WRITE:其值为7,文件写入失败
UPLOAD_ERR_EXTENSION:其值为8,上传的文件被PHP扩展程序中断

五、代码

1、单文件上传

html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Upload</title>
</head>
<body>
    <form action="index.php" method="post" enctype="multipart/form-data">
        请选择你要上传的文件:
        <input type="file" name="myFile">
        <input type="submit" value="upload">
    </form>
</body>
</html>

单文件上传方法:

<?php

/*
 * 单文件上传
 * 参数:
 * (String)$fileInfo:上传文件信息
 * (String)$path:文件存放目录
 * (Int)$maxSize:允许上传的文件最大大小,默认为2M
 * (Array)$allowExt:允许上传的文件扩展名
 * (String)$flag:是否检测上传文件是否为真实的图片类型,默认不检测
 */
function upload_single($fileInfo,$path='uploads/',$maxSize=2097152,$allowExt=null,$flag=false){

    $destination='';       //上传后新的路径名
    $data=[
        'destination'=>$destination
    ];
    //判断错误号
    if ($fileInfo['error']==0){
        //限制文件大小
        if ($fileInfo['size']>$maxSize){
            $data['msg']='上传文件过大';
            return $data;
        }
        //判断上传文件的类型
        $ext=strtolower(pathinfo($fileInfo['name'],PATHINFO_EXTENSION));
        if ($allowExt){
            if (!in_array($ext,$allowExt)){
                $data['msg']='非法文件类型';
                return $data;
            }
        }
        //检测文件是否通过HTTP POST方法上传
        if (!is_uploaded_file($fileInfo['tmp_name'])){
            $data['msg']='文件不是通过HTTP POST方式上传';
            return $data;
        }
        //检测是否为真实的图片类型,不能单纯靠扩展名
        if($flag){
            if (!getimagesize($fileInfo['tmp_name'])){
                $data['msg']='不是真正的图片类型';
                return $data;
            }
        }
        //指定目录不存在时
        if (!file_exists($path)){
            mkdir($path,0777,true);
            chmod($path,0777);
        }
        //防止文件名重名
        $uniName=md5(uniqid(microtime(true),true));
        $destination=$path.'/'.$uniName.'.'.$ext;
        if (move_uploaded_file($fileInfo['tmp_name'],$destination)){
            $data['msg']='文件传输成功';
            $data['destination']=$destination;
            return $data;
        }else{
            $data['msg']='文件移动失败';
            return $data;
        }
    }else{
        switch ($fileInfo['error']){
            case 1:
                $msg= '上传文件超过了PHP配置文件中的upload_max_filesize选项的值';
                break;
            case 2:
                $msg= '超过了表单MAX_FILE_SIZE限制的大小';
                break;
            case 3:
                $msg= '文件部分被上传';
                break;
            case 4:
                $msg= '没有选择上传文件';
                break;
            case 6:
                $msg= '没有找到临时目录';
                break;
            case 7:
                $msg= '文件写入失败';
                break;
            case 8:
                $msg= '系统错误';
                break;
        }
        $data['msg']=$msg;
        return $data;
    }
}

引用:

<?php
header('content-type:text/html;charset=utf-8');

include_once 'upload.func.php';
$allowExt=array('jpeg','jpg','png','gif','wbmp');
$fileInfo=$_FILES['myFile'];
$flag=true;
$data=upload_single($fileInfo,'uploads/', 2097152,$allowExt,$flag);
echo $data['msg'];
2、多文件上传
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Upload</title>
</head>
<body>
    <form action="index.php" method="post" enctype="multipart/form-data">
        请选择你要上传的文件:<input type="file" name="myFile1"><br/>
        请选择你要上传的文件:<input type="file" name="myFile2"><br/>
        请选择你要上传的文件:<input type="file" name="myFile3"><br/>
        请选择你要上传的文件:<input type="file" name="myFile4"><br/>
        <input type="submit" value="upload">
    </form>
</body>
</html>

上传方法文件增加一个函数:

function getFiles(){
    $i=0;
    foreach ($_FILES as $file) {
        if (is_string($file['name'])) {
            $files[$i] = $file;
            $i++;
        } elseif (is_array($file['name'])) {
            foreach ($file['name'] as $key => $val) {
                $files[$i]['name'] = $file['name'][$key];
                $files[$i]['type'] = $file['type'][$key];
                $files[$i]['tmp_name'] = $file['tmp_name'][$key];
                $files[$i]['error'] = $file['error'][$key];
                $files[$i]['size'] = $file['size'][$key];
                $i++;
            }
        }
    }
    return $files;
}

引用:

<?php
header('content-type:text/html;charset=utf-8');
include_once 'upload.func.php';
$allowExt=array('jpeg','jpg','png','gif','wbmp');
$flag=true;
foreach ($_FILES as $fileInfo){
    $data=upload_single($fileInfo,'uploads/', 2097152,$allowExt,$flag);
    echo $data['msg'].'<br/>';
}

六、下载

html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Upload</title>
</head>
<body>
<a href="index.php?filename=1.jpg" ><button value="">点击下载</button></a>
</body>
</html>

php:

<?php
$filename=$_GET['filename'];
header('content-disposition:attachment;filename='.basename($filename));
header('content-length:'.filesize($filename));
readfile($filename);
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值