很多时候我们都会用到referer地址,通过判断上一页是从哪里来的,我们可以了解很多
信息,但是现在referer并不是那么可靠的数据了,因为我们可以伪造referer地址。这里
分别介绍CURL、SOCKET、file_get_contents实现方法,详细代码如下:
CURL方式-
- $ch = curl_init();
- curl_setopt ($ch, CURLOPT_URL, "http://www.xinran001.com");
- curl_setopt ($ch, CURLOPT_REFERER, "http://www.xinran001.com/");
- curl_exec ($ch);
- curl_close ($ch);
复制代码 SOCKET方式-
- $server ='www.xinran001.com';
- $host ='www.xinran001.com';
- $target ='index.php';
- $referer ='http://www.xinran001.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.xinran001.com,你可以
写一段代码:
$_SERVER['HTTP_REFERER'];
查看到这个referer地址,就是这么简单,所以referer也不是什么可靠的数据了。 |