PHP 怎样上传文件和下载
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 怎样上传文件和下载的具体内容,更多请关注百分百源码网其它相关文章!