比如我放納米盤裡的檔案http://img.namipan.com/downfile/da333ee178bdad6531d1ec1540cf86277c116b6300887600/02.Paid%20In%20Full.mp3
這個地址不能直接下載也不能在網頁播放器裡播放,點擊下載轉到了一個下載頁面。要想能夠直接下載這個檔案或播放這個檔案,那就要偽造referfer,欺騙伺服器,referfer是來自納米盤的連結。
最開始使用的方法是用PHP內建的函數stream_context_create。
代碼如下:
function referfile($url, $refer=”) {
$opt=array('http'=>array('header'=>”Referer: $refer”));
$context=stream_context_create( $opt);
return file_get_contents($url,false, $context);
}
但這段代碼有個缺點,file_get_contents實際上是把對方伺服器的檔案讀取到了自己的伺服器上然後再發送給瀏覽器,不但加大自己伺服器的壓力,而且下載反應速度還很慢,這個並不是很好的解決方案。
後來又看了遍手冊,既要減輕自己伺服器的壓力,又能達到迷惑對方伺服器。修改header裡的Referfer資訊就可以了。
改版後的代碼如下:
$url=”img.namipan.com/downfile/da333ee178bdad6531d1ec1540cf86277c116b6300887600/02.Paid%20In%20Full.mp3″;//這裡的url要過濾掉http://
$urlarr=explode(”/”,$url);
$domain=$urlarr[0];//分解出網域名稱
$getfile=str_replace($urlarr[0],”,$url);
$content = @fsockopen(”$domain”, 80, $errno, $errstr, 12);//先串連上對方的伺服器
if (!$content){//無法連結就提示錯誤資訊
die(”對不起,無法串連上 $domain 。”);
}
fputs($content, “GET $getfile HTTP/1.0\r\n”);
fputs($content, “Host: $domain\r\n”);
fputs($content, “Referer: $domain\r\n”);//偽造referfer
fputs($content, “User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)\r\n\r\n”);
while (!feof($content)) {
$tp.=fgets($content, 128);將頭部資訊讀取出來,裡面將包含:Location:http://xxx/xxx.mp3,我們要的就是這個地址。
}
$arr=explode(”\n”,$tp);
$arr1=explode(”Location: “,$tp);
$arr2=explode(”\n”,$arr1[1]);//分解出Location:後面的地址
header('Content-Type:application/force-download');
header(”location:”.$arr2[0]);
fclose($content);
OK,目的達到了。
這個原來的地址:http://img.namipan.com/downfile/3a7c64518d46d986283eab73175a8b119305a76480b89200/Equilibrium-Turis_Fratyr-02-Wingthors_Hammer.mp3
轉換後:
http://mms.music.krmcn.com/mms.music/namipan/img~~/3a7c64518d46d986283eab73175a8b119305a76480b89200/Equilibrium-Turis_Fratyr-02-Wingthors_Hammer.mp3