先给大家介绍下PHP header() 函数
定义和用法
header() 函数向客户端发送原始的 HTTP 报头。
认识到一点很重要,即必须在任何实际的输出被发送之前调用 header() 函数(在 PHP 4 以及更高的版本中,您可以使用输出缓存来解决此问题):
1
2
3
4
5
6
|
<html> <?php // 结果出错 // 在调用 header() 之前已存在输出 header( 'Location: http://www.example.com/' ); ?> |
语法
1
|
header(string,replace,http_response_code) |
数 | 描述 |
---|---|
string | 必需。规定要发送的报头字符串。 |
replace |
可选。指示该报头是否替换之前的报头,或添加第二个报头。 默认是 true(替换)。false(允许相同类型的多个报头)。 |
http_response_code | 可选。把 HTTP 响应代码强制为指定的值。(PHP 4 以及更高版本可用) |
php文件下载可以使用http的请求头加上php的IO可以实现,很久之前写过这么一个功能,后来代码没了,今天记录一下
1、先看一下一个正常的http请求
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
HTTP/1.1 200 OK Server: Tengine Content-Type: application/octet-stream Content-Length: 5050697 Connection: keep-alive Date : Thu, 12 Oct 2017 11:24:46 GMT Accept-Ranges: bytes Content-Disposition: attachment; filename=down/20170928/zjbb_2.9.5.apk Expires: Thu, 12 Oct 2017 11:25:46 GMT Cache-Control: max-age=60 Via: cache25.l2eu6-1[0,200-0,H], cache16.l2eu6-1[16,0], cache8.cn891[0,200-0,H], cache8.cn891[1,0] Age: 1733678 X-Cache: HIT TCP_MEM_HIT dirn:6:277104755 mlen:-1 X-Swift-SaveTime: Sat, 14 Oct 2017 00:50:47 GMT X-Swift-CacheTime: 93312000 Timing-Allow-Origin: * EagleId: b73d0e1c15095411645886178e |
2、一些常见的header功能
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
header( 'HTTP/1.1 200 OK' ); // ok 正常访问 header( 'HTTP/1.1 404 Not Found' ); //通知浏览器 页面不存在 header( 'HTTP/1.1 301 Moved Permanently' ); //设置地址被永久的重定向 301 header( 'Location: http://www.test.con/' ); //跳转到一个新的地址 header( 'Refresh: 10; url=http://www.test.con/' ); //延迟转向 也就是隔几秒跳转 header( 'X-Powered-By: PHP/7.0.0' ); //修改 X-Powered-By信息 header( 'Content-language: en' ); //文档语言 header( 'Content-Length: 1234' ); //设置内容长度 header( 'Last-Modified: ' . gmdate ( 'D, d M Y H:i:s' , $time ). ' GMT' ); //告诉浏览器最后一次修改时间 header( 'HTTP/1.1 304 Not Modified' ); //告诉浏览器文档内容没有发生改变 ###内容类型### header( 'Content-Type: text/html; charset=utf-8' ); //网页编码 header( 'Content-Type: text/plain' ); //纯文本格式 header( 'Content-Type: image/jpeg' ); //JPG、JPEG header( 'Content-Type: application/zip' ); // ZIP文件 header( 'Content-Type: application/pdf' ); // PDF文件 header( 'Content-Type: audio/mpeg' ); // 音频文件 header( 'Content-type: text/css' ); //css文件 header( 'Content-type: text/javascript' ); //js文件 header( 'Content-type: application/json' ); //json header( 'Content-type: application/pdf' ); //pdf header( 'Content-type: text/xml' ); //xml header( 'Content-Type: application/x-shockw**e-flash' ); //Flash动画 ###### ###声明一个下载的文件### header( 'Content-Type: application/octet-stream' ); header( 'Content-Disposition: attachment; filename="ITblog.zip"' ); header( 'Content-Transfer-Encoding: binary' ); readfile( 'test.zip' ); ###### ###对当前文档禁用缓存### header( 'Cache-Control: no-cache, no-store, max-age=0, must-revalidate' ); header( 'Expires: Mon, 26 Jul 1997 05:00:00 GMT' ); ###### ###显示一个需要验证的登陆对话框### header( 'HTTP/1.1 401 Unauthorized' ); header( 'WWW-Authenticate: Basic realm="Top Secret"' ); ###### ###声明一个需要下载的xls文件### header( 'Content-Disposition: attachment; filename=abc.xlsx' ); header( 'Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' ); header( 'Content-Length: ' . filesize ( './test.xls' )); header( 'Content-Transfer-Encoding: binary' ); header( 'Cache-Control: must-revalidate' ); header( 'Pragma: public' ); readfile( './test.xls' ); |
3、看下下载所要用的的请求头
1
2
3
4
|
header( "Content-type:application/octet-stream" ); header( "Accept-Ranges:bytes" ); header( "Accept-Length:" . $file_Size ); header( "Content-Disposition: attachment; filename=" . $filename ); |
- content-type:文件类型
- Accept-Ranges:表示接收数据的类型或者范围,图片属于二进制的东西所以需要使用字节的方式传输
- Accept-Length:表示接收的文件大小,php文件下载需要告诉浏览器下载的文件有多大
- Content-Disposition:附件只需要把文件名给过去就可以,这个名称就是下载时显示的文件名称
4、php的文件操作出现的比较早,文件名是中文的时候需要注意转码
1
|
$filename =iconv( "UTF-8" , "GB2312" , $filename ); |
5、php的文件下载机制是首先nginx把文件信息读入服务器内存,然后使用请求头把文件二进制信息通过浏览器传给客户端
feof用来判断文件是否已经读到了末尾,fread用来把文件读入缓冲区,缓冲区的大小是1024,一边读取一边把数据输出到浏览器。为了下载的安全性每次读数据都进行字节的计数。文件读取完毕后关闭输入流
注意:
a、如果运行的过程中出现问题,可以清空(擦掉)输出缓冲区,使用下面的代码即可
ob_clean();
b、很多人喜欢用readfile,如果是大文件,可能会有问题
完整代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
<?php ob_clean(); $action = $_GET [ 'action' ]; $filename = base64_decode ( $action ); //传的参数encode了 $filepath = '/data/www/www.test.com/' . $filename ; if (! file_exists ( $filepath )){ exit ; } $fp = fopen ( $filepath , "r" ); $filesize = filesize ( $filepath ); header( "Content-type:application/octet-stream" ); header( "Accept-Ranges:bytes" ); header( "Accept-Length:" . $filesize ); header( "Content-Disposition: attachment; filename=" . $filename ); $buffer =1024; $buffer_count =0; while (! feof ( $fp )&& $file_Size - $buffer_count >0){ $data = fread ( $fp , $buffer ); $buffer_count += $buffer ; echo $data ; } fclose( $fp ); ?> |
PS:下面看一段实例代码php如何通过header文件头实现文件下载
具体代码如下所示:
1
2
3
4
5
6
7
8
9
10
11
|
$file = $_GET [ 'file' ]; if ( file_exists ( $file )){ header( "Content-type:application/octet-stream" ); $filename = basename ( $file ); header( "Content-Disposition:attachment;filename = " . $filename ); header( "Accept-ranges:bytes" ); header( "Accept-length:" . filesize ( $file )); readfile( $file ); } else { echo "<script>alert('文件不存在')</script>" ; } |
总结
以上所述是小编给大家介绍的PHP使用header方式实现文件下载功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:http://www.cnblogs.com/chenpingzhao/p/7768584.html?utm_source=tuicool&utm_medium=referral