如何讓PHP支持斷點續傳文件_PHP教程
推薦:PHP判斷搜索引擎機器人Robot有朋友問到如何使用PHP去判斷是否是搜索引擎,其實PHP有個很簡單的方式去實現,通過_SERVER這個預定義變量中的_SERVER['HTTP_USER_AGENT']可以取得訪問者的屬性,具體可以看下Diiscuz!是如何判斷搜索引擎的,函數代碼如下: function getrobot() { if(!defin
現在的很多服務器都支持斷點續傳去下載軟件,同時很多下載軟件也是斷點續傳,怎么樣才能讓PHP也能實現斷電續傳功能呢?請先看下面的代碼。
fname = './05e58c19552bb26b158f6621a6650899';
fp = fopen(fname,'rb');
fsize = filesize(fname);
if (isset(_SERVER['HTTP_RANGE']) && (_SERVER['HTTP_RANGE'] != "") && preg_match("/^bytes=([0-9]+)-/i", _SERVER['HTTP_RANGE'], match) && (match[1] < fsize)) {
start = match[1];
} else {
start = 0;
}
@header("Cache-control: public");
@header("Pragma: public");
if (start > 0) {
fseek(fp, start);
Header("HTTP/1.1 206 Partial Content");
Header("Content-Length: " . (fsize - start));
Header("Content-Ranges: bytes" . start . "-" . (fsize - 1) . "/" . fsize);
} else {
header("Content-Length: fsize");
Header("Accept-Ranges: bytes");
}
@header("Content-Type: application/octet-stream");
@header("Content-Disposition: attachment;filename=1.rm");
fpassthru(fp);
其實說簡單點就是通過這個變量_SERVER['HTTP_RANGE']取得用戶請求的文件的range,然后程序去控制文件的輸出。比如第一次請求一個文件的從0到999字節,第二次請求1000到1999字節,以此類推,每次請求1000字節的內容,然后程序通過fseek函數去取得對應的文件位置,然后輸出。
大家也可以看下Discuz!論壇軟件的attachment.php文件是如何實現斷點續傳的。請看代碼:
range = 0;
if(readmod == 4) {
dheader('Accept-Ranges: bytes');
if(!empty(_SERVER['HTTP_RANGE'])) {
list(range) = explode('-',(str_replace('bytes=', '', _SERVER['HTTP_RANGE'])));
rangesize = (filesize - range) > 0 ? (filesize - range) : 0;
dheader('Content-Length: '.rangesize);
dheader('HTTP/1.1 206 Partial Content');
dheader('Content-Range: bytes='.range.'-'.(filesize-1).'/'.(filesize));
}
}
也是通過_SERVER['HTTP_RANGE']取得用戶請求的文件的range,具體的大家可以查看其源碼分析下。這里我就當拋磚引玉了。
分享:PHP的print函數PHP的print函數,姑且說是函數吧
- 相關鏈接:
- 教程說明:
PHP教程-如何讓PHP支持斷點續傳文件
。