したがって、ホットリンクを防ぐ対策を検討する場合は、HTTP_REFERER の操作を検討する必要があります。 PHP スクリプト内の対応する変数は $_SERVER['HTTP_REFERER'] で、HTTP_REFERER の値が格納されます。
上記のホットリンク対策により対象のURLリソースへの直接アクセスがブロックされているため、それを取得するにはゲートウェイのようなものが必要です。端的に言えば、HTTP ヘッダーをラップした PHP スクリプトを書くことです。
以下は簡単な関数の実装です:
コードをコピー コードは次のとおりです:
function getRemoteFile($url, $refer = '') {
$option = array(
'http' => 配列 (
'header' => "リファラー:$refer")
$context = stream_context_create($option);
return file_get_contents($url, false, $context);
これは比較的単純な関数です。その機能は、Referer を偽造し (stream_context_create 関数を使用)、相手のデータを取得することです (file_get_contents を使用し、allow_url_fopen を有効にする必要があります)。
より「複雑」にしたい場合は、ソケット拡張機能を使用できますが、これについてはここでの説明の範囲を超えています。
さらに、ホスト名を取得するための通常の関数を提供します
コードをコピーします
コードは次のとおりです:
function getHost($url) { $result = preg_match('/^http:/ /([d| w|.]+)//', $url, $matches); if (sizeof($matches) >= 2) {
return $matches[1]} else {
return null;
}
}
はさらに拡張してスクリプトにカプセル化し、たとえば
http://127.0.0.1/proxy.php?url=http://i.am を呼び出すことができます。 /img は、これらのホットリンク対策リンクを取得できます (さらに開発するには、JavaScript を使用してすべての画像リンクを置き換えます)。
http://www.bkjia.com/PHPjc/322994.html
www.bkjia.com
true
http://www.bkjia.com/PHPjc/322994.html技術記事したがって、ホットリンクを防ぐ対策を検討する場合は、HTTP_REFERER の操作を検討する必要があります。 PHP スクリプト内の対応する変数は $_SERVER['HTTP_REFERER'] で、HTTP_REFER が格納されます...