在php中,有些时候需要实时查看页面或者链接,比如股票行情等,如果使用缓存可能不能更新实时价格,需要禁用缓存,代码如下:
header("Expires: -1");
header("Cache-Control: no_cache");
header("Pragma: no-cache");
上面这3句话都是禁用缓存,主要是为了不同浏览器识别,所以都写上,以便可以支持所有浏览器。
文件的下载的过程
1.浏览器发起请求,
2.服务器把数据进行读入,
3.服务器把数据返回给浏览器
4.浏览器接受数据,通过协进判断是保存数据,写入到用户指定位置
php需要做的事读入数据,并返回给请求客户端。代码如下:
// $fileSubDir 应该是 /XXX/XXX/
function downFile($fileName ,$fileSubDir){ //浏览器需要传输过来文件名和文件存储的子目录,这个网页中提前写好的
//如果是中文,需要进行转码 gb2312
$fileName=iconv("utf-8", "gb2312", $fileName); //php默认是utf-8,需要转换成gb2312
//拼成文件路径
$filePath=$_SERVER['DOCUMENT_ROOT'].$fileSubDir.$fileName
if (!file_exists($filePath)){
echo "文件不存在!"
return
}
//文件存在就打开文件
$fp=fopen($filePath,"r");
//获取下载的文件大小
$fileSize=filesize($filePath);
//告诉浏览器,返回的是一个文件的形式,不需要做展示
header("Content-type: application/octet-stream");
//返回的数据大小单位:字节
header("Accept-Ranges: bytes");
//浏览器弹出的对话框中的文件名
header("Content-Disposition: attachment; filename=".$fileName);
//向客户端回送数据
$buffer=1024; //每次回送的数据大小
//为了下载安全,我们做一个文件字节读取计数器
$file_count=0;
while(!feof($fp)&&($fileSize-$file_count>0)){
//每次从数据中读取1024数据
$file_data=fread($fp,$buffer);
$file_count+=$buffer;//累计统计读取了多少字节
echo $file_data;这句话就是把数据回送给浏览器
}
fclose($fp);
}