欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

用PHP偽造referer突破網(wǎng)盤禁止外連的代碼

 更新時(shí)間:2008年06月15日 18:51:57   作者:  
一般的國(guó)內(nèi)網(wǎng)盤為控制流量,都會(huì)禁止網(wǎng)盤內(nèi)的文件外鏈。點(diǎn)網(wǎng)盤里文件的鏈接一般都會(huì)轉(zhuǎn)到專門的下載頁(yè)面,必須從這個(gè)頁(yè)面才能下載文件。

比如我放納米盤里的文件http://img.namipan.com/downfile/da333ee178bdad6531d1ec1540cf86277c116b6300887600/02.Paid%20In%20Full.mp3

這個(gè)地址不能直接下載也不能在網(wǎng)頁(yè)播放器里播放,點(diǎn)擊下載轉(zhuǎn)到了一個(gè)下載頁(yè)面。要想能夠直接下載這個(gè)文件或播放這個(gè)文件,那就要偽造referfer,欺騙服務(wù)器,referfer是來(lái)自納米盤的鏈接。

最開始使用的方法是用PHP內(nèi)置的函數(shù)stream_context_create。

代碼如下: 

復(fù)制代碼 代碼如下:

function referfile($url, $refer=”) {
$opt=array('http'=>array('header'=>”Referer: $refer”));
$context=stream_context_create( $opt);
return file_get_contents($url,false, $context);
}


但這段代碼有個(gè)缺點(diǎn),file_get_contents實(shí)際上是把對(duì)方服務(wù)器的文件讀取到了自己的服務(wù)器上然后再發(fā)送給瀏覽器,不但加大自己服務(wù)器的壓力,而且下載反應(yīng)速度還很慢,這個(gè)并不是很好的解決方法。

后來(lái)又看了遍手冊(cè),既要減輕自己服務(wù)器的壓力,又能達(dá)到迷惑對(duì)方服務(wù)器。修改header里的Referfer信息就可以了。

改版后的代碼如下:
復(fù)制代碼 代碼如下:

<?php
$url="img.namipan.com/downfile/da333ee178bdad6531d1ec1540cf86277c116b6300887600/02.Paid%20In%20Full.mp3";//這里的url要過(guò)濾掉http://
$urlarr=explode("/",$url);
$domain=$urlarr[0];//分解出域名
$getfile=str_replace($urlarr[0],",$url);
$content = @fsockopen("$domain", 80, $errno, $errstr, 12);//先連接上對(duì)方的服務(wù)器
if (!$content){//無(wú)法鏈接就提示錯(cuò)誤信息
die("對(duì)不起,無(wú)法連接上 $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);將頭部信息讀取出來(lái),里面將包含:Location:http://xxx/xxx.mp3,我們要的就是這個(gè)地址。
}
$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,目的達(dá)到了。

這個(gè)原來(lái)的地址:http://img.namipan.com/downfile/3a7c64518d46d986283eab73175a8b119305a76480b89200/Equilibrium-Turis_Fratyr-02-Wingthors_Hammer.mp3

轉(zhuǎn)換后:

http://mms.music.krmcn.com/mms.music/namipan/img~~/3a7c64518d46d986283eab73175a8b119305a76480b89200/Equilibrium-Turis_Fratyr-02-Wingthors_Hammer.mp3

附另外一段實(shí)現(xiàn)代碼:

最原始的破解網(wǎng)盤限制外鏈的php代碼,如果各位想要學(xué)習(xí)研究可以繼續(xù)看,如果要拿代碼直接用需要改進(jìn),這個(gè)代碼僅供參考學(xué)習(xí)。

新建一個(gè)文件file.php。后面的參數(shù)就是需要偽造referfer的目標(biāo)地址吧。如:file.php/http://www.xxx.xxx/xxx.mp3

復(fù)制代碼 代碼如下:

<?
$url=str_replace('/file.php/','',$_SERVER["REQUEST_URI"]);//得出需要轉(zhuǎn)換的網(wǎng)址。這里我就偷懶,不做安全檢測(cè)了,需要的自己加上去
$downfile=str_replace(" ","%20",$url);//替換空格之類,可以根據(jù)實(shí)際情況進(jìn)行替換
$downfile=str_replace("http://","",$downfile);//去掉http://
$urlarr=explode("/",$downfile);//以"/"分解出域名
$domain=$urlarr[0];//域名
$getfile=str_replace($urlarr[0],'',$downfile);//得出header中的GET部分
$content = @fsockopen("$domain", 80, $errno, $errstr, 12);//連接目標(biāo)主機(jī)
if (!$content){//鏈接不上就提示錯(cuò)誤
die("對(duì)不起,無(wú)法連接上 $domain 。");
}
fputs($content, "GET $getfile HTTP/1.0\r\n");
fputs($content, "Host: $domain\r\n");
fputs($content, "Referer: $domain\r\n");//偽造部分
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);
if (strstr($tp,"200 OK")){ //這里要說(shuō)明一下。header的第一行一般是請(qǐng)求文件的狀態(tài)。具體請(qǐng)參照HTTP 1.1狀態(tài)代碼及其含義hi.baidu.com/110911/blog/item/21f20d2475af812ed50742c5.html這里 是正常的文件請(qǐng)求狀態(tài),只需直接轉(zhuǎn)向就可以。其他狀態(tài)的繼續(xù)執(zhí)行程序

header("Location:$url");
die();
}
}

//302 轉(zhuǎn)向,大部分的防盜鏈系統(tǒng)都是先判斷referfer,對(duì)了的話再轉(zhuǎn)向真實(shí)的地址。下面就是獲取真實(shí)的地址。
$arr=explode("\n",$tp);
$arr1=explode("Location: ",$tp);//分解出Location后面的真時(shí)地址
$arr2=explode("\n",$arr1[1]);
header('Content-Type:application/force-download');//強(qiáng)制下載
header("location:".$arr2[0]);//轉(zhuǎn)向目標(biāo)地址
die();
?>

115網(wǎng)盤圖片外鏈測(cè)試(不是我做的):原版地址:http://u.115.com/file/f3b7c9046
外鏈地址:http://115.pp.ru/f3b7c9046/02.jpg

115網(wǎng)盤外鏈測(cè)試2(也不是我做的):http://gg.org.ru/115.php/提取碼/xxx

相關(guān)文章

  • php防止網(wǎng)站被刷新的方法匯總

    php防止網(wǎng)站被刷新的方法匯總

    這篇文章主要介紹了php防止網(wǎng)站被刷新的方法,實(shí)例匯總了常見(jiàn)的PHP防刷新技巧及應(yīng)用實(shí)例,具有不錯(cuò)的參考借鑒價(jià)值,需要的朋友可以參考下
    2014-12-12
  • 編寫php應(yīng)用程序?qū)崿F(xiàn)摘要式身份驗(yàn)證的方法詳解

    編寫php應(yīng)用程序?qū)崿F(xiàn)摘要式身份驗(yàn)證的方法詳解

    本篇文章是對(duì)編寫php應(yīng)用程序?qū)崿F(xiàn)摘要式身份驗(yàn)證的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • 關(guān)于Zend Studio 配色方案插件的介紹

    關(guān)于Zend Studio 配色方案插件的介紹

    本篇文章是對(duì)Zend Studio 配色方案插件的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • php使用cookie顯示用戶上次訪問(wèn)網(wǎng)站日期的方法

    php使用cookie顯示用戶上次訪問(wèn)網(wǎng)站日期的方法

    這篇文章主要介紹了php使用cookie顯示用戶上次訪問(wèn)網(wǎng)站日期的方法,主要通過(guò)使用cookie保存訪問(wèn)時(shí)間來(lái)實(shí)現(xiàn)該功能,需要的朋友可以參考下
    2015-01-01
  • PHP-FPM的配置與優(yōu)化講解

    PHP-FPM的配置與優(yōu)化講解

    今天小編就為大家分享一篇關(guān)于PHP-FPM的配置與優(yōu)化講解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-03-03
  • 如何判斷php數(shù)組的維度

    如何判斷php數(shù)組的維度

    本篇文章是對(duì)判斷php數(shù)組維度的代碼進(jìn)行了詳細(xì)的分析介紹, 需要的朋友參考下
    2013-06-06
  • 9個(gè)實(shí)用的PHP代碼片段分享

    9個(gè)實(shí)用的PHP代碼片段分享

    這篇文章主要介紹了9個(gè)實(shí)用的PHP代碼片段分享,本文講解了查看郵件是否已被閱讀、從網(wǎng)頁(yè)中提取關(guān)鍵詞、查找頁(yè)面上的所有鏈接、自動(dòng)轉(zhuǎn)換URL為可點(diǎn)擊超鏈接等內(nèi)容,需要的朋友可以參考下
    2015-01-01
  • php的mssql數(shù)據(jù)庫(kù)連接類實(shí)例

    php的mssql數(shù)據(jù)庫(kù)連接類實(shí)例

    這篇文章主要介紹了php的mssql數(shù)據(jù)庫(kù)連接類,以一個(gè)類實(shí)例的形式演示了PHP實(shí)現(xiàn)針對(duì)mssql數(shù)據(jù)庫(kù)的各種常用操作方法,包括對(duì)數(shù)據(jù)庫(kù)的連接與增刪改查等操作,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2014-11-11
  • php縮放圖片(根據(jù)寬高的等比例縮放)實(shí)例介紹

    php縮放圖片(根據(jù)寬高的等比例縮放)實(shí)例介紹

    設(shè)定寬高,不等比例縮放;設(shè)定寬度,等比例縮放;設(shè)定高度,等比例縮放;按比例,縮放至50%;縮放后直接輸出到屏幕等等,具體使用方法如下,感興趣的額朋友可以了解下哈
    2013-06-06
  • 讓你的PHP7更快之Hugepage用法分析

    讓你的PHP7更快之Hugepage用法分析

    這篇文章主要介紹了讓你的PHP7更快之Hugepage用法,較為詳細(xì)的分析了php7中Hugepage的功能與具體的設(shè)置技巧,需要的朋友可以參考下
    2016-05-05

最新評(píng)論