php 伪造HTTP_REFERER页面URL来源的三种方法

Posted 雪剑无影

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php 伪造HTTP_REFERER页面URL来源的三种方法相关的知识,希望对你有一定的参考价值。

php获取当前页面的前一个页面URL地址,即当前页面是从哪个页面链接过来的,可以使用$_SERVER[‘HTTP_REFERER‘];

但是$_SERVER[‘HTTP_REFERER‘]也是可以被伪造欺骗的,有三种方法可以伪造和欺骗$_SERVER[‘HTTP_REFERER‘]

第一种方法: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;

ile_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, $port=80,$t=30);

 

以上是关于php 伪造HTTP_REFERER页面URL来源的三种方法的主要内容,如果未能解决你的问题,请参考以下文章

PHP $_SERVER['HTTP_REFERER'] 获取前一页面的 URL 地址

请问下 php 怎么获取 ajax 请求 来源页面的 完整 url 地址啊?

PHP怎么获取来源域名

PHP中获取当前页面的URL信息

在PHP中截取当前页面URL地址及URL信息的方法

php curl 伪造IP来源的实例代码