hi,你好!欢迎访问本站!登录
本站由网站地图腾讯云宝塔系统阿里云强势驱动
当前位置:首页 - 教程 - 后端开发 - 正文 君子好学,自强不息!

【后端开辟】PHP 怎样上传文件和下载

2019-11-20后端开发搜奇网61°c
A+ A-
第 1 章 文件上传

1.1 客户端上传设置

在 B/S 顺序中文件上传已成为一个经常运用功用。其目的是客户能够经由过程浏览器 (Browser) 将文件上传到服务器(Server)上的指定目次。

收集上罕见的支撑文件上传的网站:

种种网盘

头像

收集相册

实名认证

邮件附件

简朴来讲就是,Web 开辟须要用户通报给服务器文件的都属于 PHP 的上传领域。而服务器端只能吸收的份,除非不做这个功用。就像 10086 客服,你只需打过去,它就要吸收,不吸收只能是服务器忙碌。

PHP 中文件上传的基础知识:

1)客户端 form 表单设置

2) 服务器对上传文件举行操纵处置惩罚

必需设置的 form 表单项:

<html>
    <head><title>文件上传</title></head>
    <body>
        <form action="./upload.php"  method="post" enctype="multipart/form-data"><!--必需要写-->
            <!--typle写file范例,name必需要写,名字随意-->
            挑选文件:<input type="file" name="myfile">
            <input type="submit" value="上传文件">
        </form>
    </body>
</html>

注重几个特性属性:

1. 肯定是 post 体式格局上传文件,不可用 get 体式格局。

2. form 表单中肯定要写 enctype="multipart/form-data"。

3. input 表单肯定要写 name 名。

1.2 在服务器端经由过程 PHP 处置惩罚上传

上传文件的吸收和处置惩罚是经由过程 PHP 剧本来处置惩罚的,细致须要经由过程以下三个方面信息:

1)设置 PH 配置文件中的指令:用于精细地调治 PHP 的文件上传功用。

2)$FILES 多维数组:用于存储种种与上传文件有关的信息,其他数据照样运用 $_POST 猎取。

3)PHP 的文件上传处置惩罚函数:用于上传文件的后续处置惩罚。

1)PHP 配置文件中与文件上传有关的选项。

2)$_FILES 多维数组。

超等全局数组 $_FILES

1、$_FILES["myfile"]["name"]中的值是:客户端文件体系的文件的称号。

2、$FILES["myfile"]["type"]中的值是:客户端通报的文件的范例。

3、$_FILES["myfile"]["size"]中的值是:文件的字节的大小。

4、$_FILES["myfile"]["tmp_name"]中的值是:文件被上传后在服务器存储的暂时全途径。

5、$_FILES["myfile"]["error"]中的值是:文件上传的毛病代码-php 4.2今后增添的功用。

关于 error 文件上传的毛病代码:

UPLOAD_ERR_OK

其值为 0,没有毛病发作,文件上传胜利。

UPLOAD_ERR_INI_SIZE

其值为 1,上传的文件超过了 php.ini 中 upload_max_filesize 选项限定的值。

UPLOAD_ERR_FORM_SIZE

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

UPLOAD_ERR_PARTIAL

其值为 3,文件只要部份被上传。

UPLOAD_ERR_NO_FILE

其值为 4,没有文件被上传。

UPLOAD_ERR_NO_TMP_DIR

其值为 6,找不到暂时文件夹。PHP 4.3.10 和 PHP 5.0.3 引进。

UPLOAD_ERR_CANT_WRITE

其值为 7,文件写入失利。PHP 5.1.0 引进。

注重: 以上值在 PHP 4.3.0 以后变成了 PHP 常量。

罕见数据花样(MIME)

3) PHP 的文件上传处置惩罚函数

上传胜利的文件会被安排到服务器端暂时目次下,文件名是随机生成的暂时文件名。

注:该文件在顺序实行完后将自动被删撤除。在删除前能够像当地文件一样操纵。

文件上传处置惩罚函数:

is_uploaded_file — 推断文件是不是是经由过程 HTTP POST 上传的。

花样:bool is_uploaded_file (string $filename)

move_uploaded_file — 将上传的文件挪动到新位置。

花样:bool move_uploaded_file (string $filename , string $destination)

注重:假如目的文件已存在,将会被掩盖。

参数申明:文件暂时目次,要挪动到的位置目次

案例:

1) 设置前端上传界面

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <form action="doup.php" method="post" enctype="multipart/form-data">
        <input type="file" name="pic">
        <input type="submit" value="上传">
    </form>
</body>
</html>

2) doup.php 处置惩罚上传到暂时目次的文件

  //专业搬运东西
    //move_uploaded_file()
    //参数1: 文件暂时目次  参数2: 要挪动到的位置
    //is_uploaded_file() 推断文件是不是是http post提交过来的
    //参数1: 文件暂时目次
    //1.我们保留的途径根据时候来建立
    //var_dump($_GET);
    //1.1保留的途径
    $dir='./biran/'.date('Y/m/d/');
    //echo $dir;exit;
    //1.2 推断文件上传的途径是不是存在 假如不存在就建立
    if(!file_exists($dir)){
        mkdir($dir,777,true);
    }
    //2.要有个好的文件名 唯一的文件名
    //2.1猎取文件的后缀名
    //2.jpg  jpg 
    $suffix = pathinfo($_FILES['pic']['name'],PATHINFO_EXTENSION);
    //echo $suffix;
    //2.2从新起名
    $filename = date('Ymd').uniqid().mt_rand(0,9999).'.'.$suffix;
    //echo $filename;
    //最先搬运
    //推断是不是是http post 通报的文件
    if(!is_uploaded_file($_FILES['pic']['tmp_name'])){
        //不是http post上传文件
        echo '别整没用的!!';exit;
    }
    //最先真正的搬运
    if(move_uploaded_file($_FILES['pic']['tmp_name'],$dir.$filename)){
        echo '11111111111';
    }else{
        echo '22222222222';
    }

封装成函数:

思绪:

  function upload(){
        //1.推断文件上传毛病
        //2.推断你文件上传的范例是不是是你想要的范例
        //3.起名字
        //4.推断保留途径是不是存在
        //5.推断是不是是http post体式格局上传
        //6.挪动图片
        //7.返回挪动胜利的图片名
    }

最先封装函数:新建 function.php

<?php
    /*
        文件上传函数
        @param  string  $name  文件上传文件域的name值
        @param  string  $dir   文件保留途径
        @param  array   $allow 文件许可上传的范例
        return  string  $filename 文件名  假如失利 返回false
     */
    function upload($name,$dir='./upload/',$allow=array('jpg','gif','jpeg','png')){
        //echo $name;exit;
        //var_dump($_FILES);exit;
        //1.推断文件上传毛病
        if($_FILES[$name]['error']>0){
            //echo '上传毛病';
            switch($_FILES[$name]['error']){
                case 1:
                    echo '上传的文件超过了 php.ini 中upload_max_filesize 选项限定的值.';
                    break;
                case 2:
                    echo '上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值';
                    break;
                case 3:
                    echo '文件只要部份被上传.';
                    break;
                case 4:
                    echo '没有文件被上传.';
                    break;
                case 6:
                    echo '找不到暂时文件夹.';
                    break;
                case 7:
                    echo '文件写入失利.';
                    break;
            }
            return false;
        }
        //2.推断你文件上传的范例是不是是你想要的范例
        //2.1许可上传的范例
        //2.2 猎取后缀名
        $suffix = pathinfo($_FILES[$name]['name'],PATHINFO_EXTENSION);
        //echo $suffix;exit;
        //2.3 推断是不是是我们许可上传的范例
        //var_dump(in_array($suffix,$allow));exit;
        if(!in_array($suffix,$allow)){
            //不许可上传的范例
            echo  '老大你的上传范例不符合';
            return false;
        }
        //3.起名字
        $filename = date('Ymd').uniqid().mt_rand(0,9999).'.'.$suffix;
        //echo $filename;exit;
        //4.推断保留途径是不是存在
        //4.1 获得保留途径
        //4.2 处置惩罚保留途径和背面的斜杠
        $save_path = rtrim($dir,'/');
        $save_path .='/';
        //4.3 保留途径中的时候文件夹处置惩罚
        $save_path .=date('Y/m/d/');
        //4.4 推断保留的途径是不是存在
        if(!file_exists($save_path)){
            mkdir($save_path,777,true);
        }
        //4.5 拼接一个完全的保留途径
        $path = $save_path.$filename;
        //echo $path;exit;
        //5.推断是不是是httppost体式格局上传
        if(!is_uploaded_file($_FILES[$name]['tmp_name'])){
            echo '滚开!';
            return false;
        }
        //6.挪动图片
        if(!move_uploaded_file($_FILES[$name]['tmp_name'],$path)){
            echo '挪动失利';
            return false;
        }
        //7.返回挪动胜利的图片名
        return $filename;
    }

挪用函数最先上传:

<?php
    include './function.php';
    //var_dump($_FILES);exit;
    echo upload('file','./leiding',array('jpg','png'));

第 2 章 多文件上传

2.1 差别 name 称号多文件上传

当须要上传多个文件的状况,有两种完成的解决方法:

1) 运用差别的表单元素。

<input type="file" name="file_a">
<input type="file" name="file_b">
<input type="file" name="file_c">

2) 运用数组花样的表单元素。

<input type="file" name="file[]">
<input type="file" name="file[]">
<input type="file" name="file[]">

第 3 章 文件下载

1) 关于浏览器不识别的文件,能够直接应用 a 衔接下载。

  <!-- 由于他们三个浏览器不熟悉如许的范例 -->
    <a href="./downlist/1.rar">1.rar</a>
    <a href="./downlist/1.exe">1.exe</a>
    <a href="./downlist/1.avi">1.avi</a>

2) 关于浏览器不识别的,能够应用 readfile 函数。

  <!-- 浏览器熟悉如许的范例,就会被剖析 -->
    <a href="./action.php?name=1.html">1.html</a>
    <a href="./action.php?name=1.php">1.php</a>
    <a href="./action.php?name=1.txt">1.txt</a>
    <a href="./action.php?name=1.jpg">1.jpg</a>
//吸收一下name值.
$name = $_GET['name'];
//完成下载功用
//强迫浏览器弹出另存为对话框
header('content-Disposition:attachment;filename="'.$name.'"');
//此时只是下载了一个空文件,须要应用readfile读一遍一切的内容.便可下载.
$path = './downlist/'.$name;
readfile($path);

以上就是PHP 怎样上传文件和下载的细致内容,更多请关注ki4网别的相干文章!

  选择打赏方式
微信赞助

打赏

QQ钱包

打赏

支付宝赞助

打赏

  移步手机端
【后端开辟】PHP 怎样上传文件和下载

1、打开你手机的二维码扫描APP
2、扫描左则的二维码
3、点击扫描获得的网址
4、可以在手机端阅读此文章
标签:

本文来源:搜奇网

本文地址:https://www.sou7.cn/282520.html

关注我们:微信搜索“搜奇网”添加我为好友

版权声明: 本文仅代表作者个人观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。请记住本站网址https://www.sou7.cn/搜奇网。

发表评论

选填

必填

必填

选填

请拖动滑块解锁
>>