一般来说,我们可以通过直接让URL指向一个位于Document Root下面的文件,来引导用户下载文件。
但是,这样做,就没办法做一些统计,权限检查,等等的工作。于是,很多时候,我们采用让PHP来做转发,为用户提供文件下载。
$file = “/tmp/dummy.tar.gz”;
header(“Content-type: application/octet-stream”);
header('Content-Disposition: attachment; filename=“' . basename($file) . '”');
header(“Content-Length: “. filesize($file));
readfile($file);
但是这个有一个问题,就是如果文件是中文名的话,有的用户可能下载后的文件名是乱码。
于是,我们做一下修改(参考: :
$file = “/tmp/中文名.tar.gz”;
$filename = basename($file);
header(“Content-type: application/octet-stream”);
//处理中文文件名
$ua = $_SERVER[“HTTP_USER_AGENT”];
$encoded_filename = urlencode($filename);
$encoded_filename = str_replace(“+”, “%20”, $encoded_filename);
if (preg_match(“/MSIE/”, $ua)) {
header('Content-Disposition: attachment; filename=“' . $encoded_filename . '”');
} else if (preg_match(“/Firefox/”, $ua)) {
header(“Content-Disposition: attachment; filename*=”utf8''“ . $filename . '”');
} else {
header('Content-Disposition: attachment; filename=“' . $filename . '”');
}
header('Content-Disposition: attachment; filename=“' . $filename . '”');
header(“Content-Length: “. filesize($file));
readfile($file);
输出的时候,如果是Apache + PHP mod,那么还需要发送到Apache的输出缓冲区。最后才发送给用户。而对于Nginx + fpm如果他们分开部署的话,那还会带来额外的网络IO。
恩,现在看起来好多了,不过还有一个问题,那就是readfile,虽然PHP的readfile尝试实现的尽量高效,不占用PHP本身的内存,但是实际上它还是需要采用MMAP(如果支持),或者是一个固定的buffer去循环读取文件,直接输出。
那么,能不能不经过PHP这层,直接让Webserver直接把文件发送给用户呢?
今天,我看到了一个有意思的文章:How I PHP:X-SendFile。
我们可以使用Apache的module mod_xsendfile,让Apache直接发送这个文件给用户:
$file = “/tmp/中文名.tar.gz”;
$filename = basename($file);
header(“Content-type: application/octet-stream”);
//处理中文文件名
$ua = $_SERVER[“HTTP_USER_AGENT”];
$encoded_filename = urlencode($filename);
$encoded_filename = str_replace(“+”, “%20”, $encoded_filename);
if (preg_match(“/MSIE/”, $ua)) {
header('Content-Disposition: attachment; filename=“' . $encoded_filename . '”');
} else if (preg_match(“/Firefox/”, $ua)) {
header(“Content-Disposition: attachment; filename*=”utf8''“ . $filename . '”');
} else {
header('Content-Disposition: attachment; filename=“' . $filename . '”');
}
header('Content-Disposition: attachment; filename=“' . basename($file) . '”');
//让Xsendfile发送文件
header(“X-Sendfile: $file”);
Lighttpd和Nginx也有类似的模块,大家有兴趣的可以去找找看。X-Sendfile头将被Apache处理,并且把响应的文件直接发送给Client。

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

查找方法:1、用strpos(),语法“strpos("字符串值","查找子串")+1”;2、用stripos(),语法“strpos("字符串值","查找子串")+1”。因为字符串是从0开始计数的,因此两个函数获取的位置需要进行加1处理。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

SublimeText3 Mac version
God-level code editing software (SublimeText3)

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

Zend Studio 13.0.1
Powerful PHP integrated development environment
