返回列表 回复 发帖

用PHP伪造referer地址

很多时候我们都会用到referer地址,通过判断上一页是从哪里来的,我们可以了解很多

信息,但是现在referer并不是那么可靠的数据了,因为我们可以伪造referer地址。这里

分别介绍CURL、SOCKET、file_get_contents实现方法,详细代码如下:

CURL方式

  1. $ch = curl_init();
  2. curl_setopt ($ch, CURLOPT_URL, "http://www.xinran001.com");
  3. curl_setopt ($ch, CURLOPT_REFERER, "http://www.xinran001.com/");
  4. curl_exec ($ch);
  5. curl_close ($ch);
复制代码
SOCKET方式

  1. $server ='www.xinran001.com';
  2. $host ='www.xinran001.com';
  3. $target ='index.php';
  4. $referer ='http://www.xinran001.com/'; // Referer
  5. $port = 80;
  6. $fp = fsockopen($server, $port, $errno, $errstr, 30);
  7. if (!$fp)
  8. {
  9. echo "$errstr ($errno)\n";
  10. }
  11. else
  12. {
  13. $out = "GET $target HTTP/1.1\r\n";
  14. $out .= "Host: $host\r\n";
  15. $out .= "Referer: $referer\r\n";
  16. $out .= "Connection: Close\r\n\r\n";
  17. fwrite($fp, $out);
  18. while (!feof($fp))
  19. {
  20. echo fgets($fp, 128);
  21. }
  22. fclose($fp);
  23. }
复制代码
file_get_contents方法

  1. $opt=array('http'=>array('header'=>"Referer: $refer"));
  2. $context=stream_context_create($opt);
  3. $file_contents = file_get_contents($url,false, $context);
复制代码
通过上面的代码,我们就把referer地址伪装为http://www.xinran001.com,你可以

写一段代码:

$_SERVER['HTTP_REFERER'];

查看到这个referer地址,就是这么简单,所以referer也不是什么可靠的数据了。
返回列表