PHP チュートリアルの http_referer 関数を使用して、ユーザーがどこから来たのかを判断します。これは簡単です。
例
if (isset($_SERVER['HTTP_REFERER'])) {
Print "以前アクセスしていたページは {$_SERVER['HTTP_REFERER']} でした
";
} else {
「ここに到達するためにリンクをレベルアップしていませんでした
」を印刷します ";
}
?>クリックしてください!
今度はユーザーに私たちの起源を知らせないようにします
例
]$host = "www.123cha.com";
$referer = "http://".$host;
$fp = fsockopen ($host, 80, $errno, $errstr, 30);
if (!$fp){
エコー「$errstr ($errno)
」 ;n";
}その他{
$request = "
GET/HTTP/1.1
受け入れる: image/gif、image/x-xbitmap、image/jpeg、image/pjpeg、application/x-shockwave-flash、application/vnd.ms-powerpoint、application/vnd.ms-excel、application/msword、*/ 「。」*
リファラー: http://$host
受け入れ言語: zh-cn
Accept-Encoding: gzip、deflate
ユーザーエージェント: Mozilla/4.0 (互換性; MSIE 6.0; Windows NT 5.1)
ホスト: $host
接続: 閉じる」
."ルンルン";
fputs ($fp, "$request");
その間 (!feof($fp))
{
$res[] = fgets($fp,1024);
}
$html = join("",$res);
fclose ($fp);
$fp = file_put_contents("123cha.html",$html);
「完了」をエコーします;
}[/コード]これで十分ではないですか?
しかし奇妙なのは、
[コード]
www.hao123.com
キャプチャされたページが文字化けします (http ヘッダーを除く)。これは gzip またはその他の圧縮が使用されているためですか?$host = "www.zhutiai.com"; $html = file_get_contents("http://".$host);
$fp = file_put_contents("hao123.html",$html);
「完了」をエコーします;
?>;[/コード]
でもこう捉えれば問題ありません
[コード]HTTP/1.1 200 OK 日付: Wed, 31 Aug 2005 00:59:36 GMT サーバー: Apache/1.3.27 キャッシュ制御: max-age=1296000 有効期限: Thu, 15 Sep 2005 00:59:36 GMT Last-Modified: Mon, 29 Aug 2005 13:56:00 GMT Accept-Ranges: bytes Connection: close Content-Type: text/html Content-Encoding: gzip Content-Length: 14567[/code]
圧縮されていることが判明し、長さは 14567 バイトでした
2 番目の方法でキャプチャすると、元の非圧縮 HTML は 71143 バイトになります。file_get_contents も自動的に解凍できることがわかります。
$target = '/2.php'; $referer = 'http://www.bkjia.com' //偽の HTTP_REFERER アドレスエコー「
; $fp = fsockopen($host, 80, $errno, $errstr, 30);
if (!$fp){
エコー「$errstr($errno)
」 ん」;
}
他{
$out = "
$target HTTP/1.1 を取得
ホスト: $host
リファラー: $referer
接続: 閉じるrnrn";
fwrite($fp, $out);
その間 (!feof($fp)){
エコー fgets($fp, 1024);
}
fclose($fp);
}
?>
もう 1 つの 2.php ファイルは非常に単純で、次のように現在の HTTP_REFERER サーバー値を読み取るコード行を記述するだけです。
」"; echo $_SERVER["HTTP_REFERER"];
?>