PHP使用header方式实现文件下载

php文件下载可以使用http的请求头加上php的IO可以实现,很久之前写过这么一个功能,后来代码没了,今天记录一下

1、先看一下一个正常的http请求

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功能

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、看下下载所要用的的请求头

 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的文件操作出现的比较早,文件名是中文的时候需要注意转码

$filename=iconv("UTF-8","GB2312",$filename);

5、php的文件下载机制是首先nginx把文件信息读入服务器内存,然后使用请求头把文件二进制信息通过浏览器传给客户端

feof用来判断文件是否已经读到了末尾,fread用来把文件读入缓冲区,缓冲区的大小是1024,一边读取一边把数据输出到浏览器。为了下载的安全性每次读数据都进行字节的计数。文件读取完毕后关闭输入流

注意:

a、如果运行的过程中出现问题,可以清空(擦掉)输出缓冲区,使用下面的代码即可

ob_clean();

b、很多人喜欢用readfile,如果是大文件,可能会有问题

完整代码

<?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);

?>

 

时间: 2024-11-09 04:48:15

PHP使用header方式实现文件下载的相关文章

多种方式实现文件下载功能

(1)使用 NSURLConnection 直接方式 (2)使用 NSURLConnection 代理方式 (3)使用 NSURLSession 直接方式 (4)使用 NSURLSession 代理方式 (5)使用 AFNetworking 方式 附加功能: 使用 AFNetworking 中的 AFNetworkReachabilityManager 相关操作来检查网络情况: AFNetworkReachabilityStatusReachableViaWiFi:Wi-Fi 网络下 AFNet

Ajax方式实现文件下载失败

背景:实现文件下载导出 问题描述 前端发送ajax[get/post]请求,后端生成excel文件,最后用response输出文件流,没有报错也没有文件下载提示. 遇到过这个问题的还是不少,问题出在ajax本身,解决方法和原因也都找到. 原因:文件的下载是以二进制形式进行的,ajax无法解析后台返回的文件流,所以无法处理二进制流response输出来下载文件 ajax请求只是个“字符型”的请求,即请求的内容是以文本类型存放的.文件的下载是以二进制形式进行的,ajax没法解析后台返回的文件流,所以

以ajax请求方式进行文件下载操作失败的原因及解决方案

一.失败的原因 那是因为response原因,一般请求浏览器是会处理服务器输出的response,例如生成png.文件下载等,然而ajax请求只是个“字符型”的请求,即请求的内容是以文本类型存放的.文件的下载是以二进制形式进行的,虽然可以读取到返回的response,但只是读取而已,是无法执行的,说白点就是js无法调用到浏览器的下载处理机制和程序. 二.解决方案 1)可以使用jquery创建表单并提交实现文件下载: var form = $("<form>"); form.

设置HTTP header方式

一, Server Code JSP----> <%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%> Java----> 1 <% 2 response.setHeader("Cache-Control","no-store"); 3 re

网络文件下载(提供多种下载方式)

(1)使用 NSURLConnection 直接方式 (2)使用 NSURLConnection 代理方式 (3)使用 NSURLSession 直接方式 (4)使用 NSURLSession 代理方式 (5)使用 AFNetworking 方式 附加功能: (1)使用 AFNetworking 中的 AFNetworkReachabilityManager 来检查网络情况: AFNetworkReachabilityStatusReachableViaWiFi:Wi-Fi 网络下 AFNetw

Header实现文件下载

1 function download($file){ 2 //文件根路径 3 $filename=$_SERVER['DOCUMENT_ROOT'].__ROOT__.'/'.$file; 4 //下载文件 5 if(!file_exists($filename)){ 6 $this->error("找不到文件"); 7 exit; 8 }else{ 9 header("Content-Type:text/html;charset=utf-8"); 10 h

php header运用细节

http://www.111cn.net/phper/php-function/55872.htm http://blog.sina.com.cn/s/blog_7298f36f01011dxv.html header的用法 header()函数的作用是:发送一个原始 HTTP 标头[Http Header]到客户端. 标头 (header) 是服务器以 HTTP 协义传 HTML 资料到浏览器前所送出的字串,在标头 与 HTML 文件之间尚需空一行分隔.有关 HTTP 的详细说明,可以参 RF

php header函数

Header()函数—is used to send raw HTTP headers. 1. 重定向 <?php header(“Location: http://www.jb51.net”;); exit; //在每个重定向之后都必须加上”exit”,避免发生错误,继续执行. ?> <?php header(“refresh: 2;url=http://www.jb51.net”;); echo ”正在加载,请稍等…<br/> 三秒后自动跳转值<a href=”ht

php实现文件下载代码一例

php实现文件下载代码 php实现文件下载我们需要用到header函数来发送相关信息给客户端浏览器,同时再结合filesize函数来读取文件大小并进行下载操作.简单的文件下载只需要使用HTML的连接标记<a>,并将属性href的URL值指定为下载的文件即可. 文件下载,只能处理一些浏览器不能默认识别的MIME类型文件,例如当访问book.rar文件时,浏览器并没有直接打开,而是弹出一个下载提示框,提示用户“下载”还是“打开”等处理方式.但如果需要下载后缀名为.html的网页文件.图片文件及PH