PHP上传文件和下载

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

1)客户端 form 表单设置

必须设置的 form 表单项:

<!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="file">
    <input type="submit" value="上传">
</form>
</body>
</html>

注意几个特征属性:

1. 一定是 post 方式上传文件,不可用 get 方式。

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

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

2) 服务器对上传文件进行操作处理

 在服务器端通过 PHP 处理上传

上传文件的接收和处理是通过 PHP 脚本来处理的,具体需要通过以下三个方面信息:

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

2.2)$FILES 多维数组:用于存储各种与上传文件有关的信息,其他数据还是使用 $_POST 获取。

2.3)PHP 的文件上传处理函数:用于上传文件的后续处理。

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

4)$_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 常量。

5)常见数据格式(MIME)

6) 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="file">
    <input type="submit" value="上传">
</form>
</body>
</html>

2) doup.php 处理上传到临时目录的文件

1 <?php
2 include './function.php';
3 
4 //var_dump($_FILES);exit;
5 
6 echo upload('file','./leiding',array('jpg','jpeg','png'));//第一个参数是表单input的name值

3)开始封装函数:新建 function.php

 1 <?php
 2 /*
 3     文件上传函数
 4     @param  string  $name  文件上传文件域的name值
 5     @param  string  $dir   文件保存路径
 6     @param  array   $allow 文件允许上传的类型
 7     return  string  $filename 文件名  如果失败 返回false
 8  */
 9 function upload($name, $dir = './upload/', $allow = array('jpg', 'gif', 'jpeg', 'png'))
10 {
11     //echo $name;exit;
12     //var_dump($_FILES);exit;
13     //1.判断文件上传错误
14     if ($_FILES[$name]['error'] > 0) {
15         //echo '上传错误';
16         switch ($_FILES[$name]['error']) {
17             case 1:
18                 echo '上传的文件超过了 php.ini 中upload_max_filesize 选项限制的值.';
19                 break;
20             case 2:
21                 echo '上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值';
22                 break;
23             case 3:
24                 echo '文件只有部分被上传.';
25                 break;
26             case 4:
27                 echo '没有文件被上传.';
28                 break;
29             case 6:
30                 echo '找不到临时文件夹.';
31                 break;
32             case 7:
33                 echo '文件写入失败.';
34                 break;
35         }
36         return false;
37     }
38     //2.判断你文件上传的类型是否是你想要的类型
39     //2.1允许上传的类型
40     //2.2 获取后缀名
41     $suffix = pathinfo($_FILES[$name]['name'], PATHINFO_EXTENSION);
42     //echo $suffix;exit;
43     //2.3 判断是否是我们允许上传的类型
44     //var_dump(in_array($suffix,$allow));exit;
45     if (!in_array($suffix, $allow)) {
46         //不允许上传的类型
47         echo '大哥你的上传类型不符合';
48         return false;
49     }
50     //3.起名字
51     $filename = date('Ymd') . uniqid() . mt_rand(0, 9999) . '.' . $suffix;
52     //echo $filename;exit;
53     //4.判断保存路径是否存在
54     //4.1 得到保存路径
55     //4.2 处理保存路径和后面的斜杠
56     $save_path = rtrim($dir, '/');
57     $save_path .= '/';
58     //4.3 保存路径中的时间文件夹处理
59     $save_path .= date('Y/m/d/');
60     //4.4 判断保存的路径是否存在
61     if (!file_exists($save_path)) {
62         mkdir($save_path, 777, true);
63     }
64     //4.5 拼接一个完整的保存路径
65     $path = $save_path . $filename;
66     //echo $path;exit;
67     //5.判断是否是httppost方式上传
68     if (!is_uploaded_file($_FILES[$name]['tmp_name'])) {
69         echo '滚蛋!';
70         return false;
71     }
72     //6.移动图片
73     if (!move_uploaded_file($_FILES[$name]['tmp_name'], $path)) {
74         echo '移动失败';
75         return false;
76     }
77     //7.返回移动成功的图片名
78     return $filename;
79 }

4)测试上传

第 2 章 多文件上传

2.1 不同 name 名称多文件上传

当需要上传多个文件的情况,有两种实现的解决方法:

1) 使用不同的表单元素。

1 <input type="file" name="file_a">
2 <input type="file" name="file_b">
3 <input type="file" name="file_c">

2) 使用数组格式的表单元素。

1 <input type="file" name="file[]">
2 <input type="file" name="file[]">
3 <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>

参考:https://mp.weixin.qq.com/s/V_sibEBt4dqNG8LhIPc73A(文章讲的很乱,我重新整理了一份)

原文地址:https://www.cnblogs.com/clubs/p/11937521.html