這篇文章給大家介紹php偽造referer地址的方法有哪些,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
方法:1、利用“file_get_contents($url,false,$context)”函數;2、CURL方式,利用curl_init()、curl_setopt()、curl_exec()等函數;3、利用fsockopen()函數。
本教程操作環境:windows7系統、PHP7.1版,DELL G3電腦
php獲取當前頁面的前一個頁面URL地址,即當前頁面是從哪個頁面鏈接過來的,可以使用$_SERVER['HTTP_REFERER'];
但是$_SERVER['HTTP_REFERER']也是可以被偽造欺騙的,有三種方法可以偽造和欺騙$_SERVER['HTTP_REFERER']
注:window平臺 使用phpstudy集成環境 nginx 此方法失效 ,apache 正常,其他平臺版未測試
第一種方法:file_get_contents
$url = "http://localhost/test/test.php";
$refer="http://www.aa.com";
$opt=array('http'=>array('header'=>"Referer: $refer"));
$context=stream_context_create($opt);
$file_contents = file_get_contents($url,false, $context);
echo $file_contents;file_get_contents中stream_context_create就偽造來源的重要參數了。
第二種方法:CURL
$url = "http://localhost/test/test.php"; // 請求的頁面地址 $refer="http://www.aa.com"; //偽造的頁面地址 $ch = curl_init(); curl_setopt ($ch, CURLOPT_URL,$url); curl_setopt ($ch, CURLOPT_REFERER,$refer); curl_exec ($ch); curl_close ($ch);
第三種方法:fsockopen
$url="http://localhost/test/test.php";
$target = "http://www.manongjc.com/";
/** sockopen 偽造 網站來源地址
* @parem $url 要訪問的頁面地址
* @parem $target 偽造來源頁面
* @parem $port 網站端口 默認 80
* @parem 頁面腳本執行時間 默認 30 s * */
function referer($url,$target,$port=80,$t=30)
{
$info=parse_url($url);
$fp = fsockopen($info["host"], $port, $errno, $errstr, $t);
if(!$fp)
{
echo "$errstr($errno)".PHP_EOL;
}
else
{
$out = "GET ".$info['path']." HTTP/1.1".PHP_EOL;
$out .= "Host: ".$info["host"].PHP_EOL;
$out .= "Referer: ".$target.PHP_EOL;
$out .= "Connection: Close".PHP_EOL;
$out .= PHP_EOL;
fwrite($fp, $out);
while(!feof($fp))
{
echo fgets($fp); // 發送 head 請求頭信息
}
fclose($fp);
}
}
//函數調用
referer($url,$target);關于php偽造referer地址的方法有哪些就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。