PHP基础文件下载类的简单封装
1: <?php
2: /**
3: * [FileDown 公用文件下载方法]
4: * @param [type] $filePath [文件路径(绝对路径或相对路径)]
5: */
6: function FileDown($filePath)
7: {
8: //由于php中的文件函数默认只支持gb2312编码的中文,这里使用iconv()函数转码为GB2312编码
9: $filePath = iconv("UTF-8", "GB2312//IGNORE", $filePath);
10:
11: //检测文件是否存在:
12: if(!file_exists($filePath)){
13: die("文件不存在!");
14: }
15:
16: //打开文件:
17: $file = @fopen($filePath, "r");
18:
19: // 获取文件大小
20: $fileSize = filesize($filePath);
21:
22: //获取文件名
23: $fileName =get_basename($filePath);
24:
25:
26: //添加响应头信息
27: header("Content-Type: application/octet-stream");//返回类型:二进制文件流
28: header("Accept-Ranges: bytes"); //告诉客户端以字节数组接受
29: header("Accept-Length: $fileSize"); //告诉客户端需要接受的文件大小
30: header("Content-Disposition: attachment; filename=".$fileName);//设置下载对话框中显示的文件名
31:
32: //循环读取指定大小的文件数据返回给客户端
33: $buffer=1024;
34: $sendCount=0;
35: while (!feof($file)&&($fileSize-$sendCount>0)) {
36: $sendCount+=$buffer;
37: echo fread($file, $buffer);//每次读取1024字节的文件数据返回给客户端
38: }
39:
40: // 关闭文件流
41: fclose($file);
42: }
43:
44: //根据文件路径获取文件的扩展名
45: function get_extension($filePath)
46: {
47: return pathinfo($filePath, PATHINFO_EXTENSION);
48: }
49:
50: //根据文件路径获取文件名
51: function get_basename($filePath)
52: {
53: //使用正则表达式将文件名之前的内容替换为"",返回结果
54: return preg_replace('/^.+[\\\\\\/]/', '', $filePath);
55: }
56:
57: ?>
调用示例:
1: <?php
2: //添加引用
3: require_once("FileDownService.php");
4:
5: //设置客户端页面编码
6: header("Content-Type:text/html; charset=utf-8");
7:
8: //从Request中取出fiLeName参数
9: if(isset($_REQUEST["fileName"]))
10: {
11: //设置文件的绝路径
12: $filePath = $_SERVER["DOCUMENT_ROOT"]."/downfiles/".$_REQUEST["fileName"];
13:
14: //调用文件下载方法进行下载
15: FileDown($filePath);
16: }
17:
18: ?>
PHP基础文件下载类的简单封装的更多相关文章
- 关于Spring-JDBC测试类的简单封装
关于Spring-JDBC测试类的简单封装 1.简单封装 /** * Created with IntelliJ IDEA. * * @Author: Suhai * @Date: 2022/04/0 ...
- web自动化框架—BasePage 类的简单封装
优秀的框架都有属于自己的思想,在搭建web自动化测试框架时,我们通常都遵循 PO(Page Object)思想. 简单理解就是我们会把每个页面看成一个对象,一切皆对象,面向对象编码,这样会让我们更好的 ...
- 初学JDBC,JDBC工具类的简单封装
//工具类不需要被继承 public final class JdbcUtils{ //封装数据库连接参数,便于后期更改参数值 private static String url="jdbc ...
- 【JAVA零基础入门系列】Day12 Java类的简单应用
俗话说的好,实践出真知,所以除了理论知识掌握扎实以外,更重要的是要多加操练,这样才能掌握核心科技. 今天我们就用刚学会的类来实践一下,目标便是完成上一篇中的剁手任务. 我们的商品类已经准备好了,代码重 ...
- .net core 中简单封装Dapper.Extensions 并使用sqlsuger自动生成实体类
引言 由公司需要使用dapper 同时支持多数据库 又需要支持实体类 又需要支持sql 还需要支持事务 所以采用了 dapper + dapperExtensions 并配套 生成实体类小工具的方 ...
- swift开发之--简单封装Alamofire请求类以及简单使用SnapKit
以前在swift3的时候,写过类似的,那个时候还没有很成熟的网络请求类库,在这里,还是衷心感谢大神们的付出! 具体效果如下,先上图: 点击按钮的时候,请求数据,数据结构如下: { ; reason = ...
- FMDB简单封装和使用
工具:火狐浏览器+SQLite Manager插件 ; Xcode; FMDB库; 效果: 项目地址: https://github.com/sven713/PackFMDB 主要参考这两篇博客: 1 ...
- 使用泛型简单封装NGUI的ScrollView实现滑动列表
懒,是老毛病了,周末跑了半马,跑完也是一通累,好久没锻炼了..也是懒的,有时都懒的写博客..最近看到项目中各种滑动列表框,本着要懒出水平来的原则,决定花点时间简单处理下(暂时未做列表太多时的优化):1 ...
- Google图片加载库Glide的简单封装GlideUtils
Google图片加载库Glide的简单封装GlideUtils 因为项目里用的Glide的地方比较多,所有简单的封装了以下,其实也没什么,就是写了个工具类,但是还是要把基础说下 Glide的Githu ...
随机推荐
- fileinput
# -*- coding: utf-8 -*- __author__ = 'metasequoia' import fileinput def file_input(): for line in fi ...
- 使用PreApplicationStartMethodAttribute
第一次见到这个东西是在公司的框架里,刚开始还挺郁闷怎么框架的Application_Start里没东西,初始化的那些代码都哪去了,后来通过一些线索找到了PreApplicationStartMetho ...
- 如何保持自己 fork 的项目和原始项目同步
首先先通过 github 的 web 页面 fork 目标的项目 前提是自己已经设置好了git,并且配置了相应的权限 然后使用git clone命令在本地克隆自己 fork 的项目: git clon ...
- Negative log-likelihood function
Softmax function Softmax 函数 \(y=[y_1,\cdots,y_m]\) 定义如下: \[y_i=\frac{exp(z_i)}{\sum\limits_{j=1}^m{e ...
- Struts2-----面试题汇总
1.struts2框架中,从用户发出请求到获得响应整个过程的流转图 FilterDispatcher --> ActionProxy-->Configuration Manager--&g ...
- vm centos 添加网卡 无配置文件
vm centos 添加网卡 无配置文件 解决办法 [root@test ~]# ifconfig eth0 Link encap:Ethernet HWaddr 00:0C:29:C8:41:FB ...
- ubuntu删除输入法后,循环登陆
在登陆界面ctrl+alt+F1进入tty界面,登陆账号,然后输入 dpkg -l |grep ^rc|awk '{print $2}' |sudo xargs dpkg -P 可以参考Ubuntu1 ...
- C++ 内存管理与堆栈
/*内存管理与堆栈: * # 一个由C/C++编译的程序占用的内存分为以下几个部分 * 1.栈区:由编译器自动分配释放,数据先进后出 * 2.堆区:由程序员手动分配释放,数据先进先出, * new 和 ...
- FBX .NET
https://github.com/returnString/ManagedFBX http://fbx.codeplex.com/ http://code.openhub.net/project? ...
- 修改输入框placeholder文字默认颜色-webkit-input-placeholder
html5为input添加了原生的占位符属性placeholder,高级浏览器都支持这个属性,例如: <input type="text" placeholder=" ...