PHP伪装referer地址的实用教程

很多时候我们都会用到referer地址,通过判断上一页是从哪里来的,我们可以了解很多信息,但是现在referer并不是那么可靠的数据了,因为我们 可以伪造referer地址。这里分别介绍CURL、SOCKET、file_get_contents实现方法,详细代码如下:

 

CURL方式:

$ch = curl_init();

curl_setopt ($ch, CURLOPT_URL, "http://www.shuzila.com");

curl_setopt ($ch, CURLOPT_REFERER, "http://www.ailishuo.com/");

curl_exec ($ch);

curl_close ($ch);

 

SOCKET方式:

$server = ‘www.lamiduo.com‘;

$host = ‘www.lamiduo.com‘;

$target = ‘index.php‘;

$referer = ‘http://www.lamiduo.com/‘; // Referer

$port = 80;

$fp = fsockopen($server, $port, $errno, $errstr, 30);

if (!$fp){

echo "$errstr ($errno)\n";

}else{

$out = "GET $target HTTP/1.1\r\n";

$out .= "Host: $host\r\n";

$out .= "Referer: $referer\r\n";

$out .= "Connection: Close\r\n\r\n";

fwrite($fp, $out);

while (!feof($fp)){

echo fgets($fp, 128);

}

fclose($fp);

}


file_get_contents方法:

$opt=array(‘http‘=>array(‘header‘=>"Referer: $refer"));

$context=stream_context_create($opt);

$file_contents = file_get_contents($url,false, $context);

 

通过上面的代码,我们就把referer地址伪装为http://www.boxuepai.com,你可以写一段代码:

$_SERVER[‘HTTP_REFERER‘];

查看到这个referer地址,就是这么简单,所以referer也不是什么可靠的数据了。想学习更多编程语言教程知识登录e良师益友网。


本文出自 “语过添情” 博客,请务必保留此出处http://yuguotianqing.blog.51cto.com/9292883/1547560

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。