2

PHPダウンロードファイルからファイルをホットリンクするのを防ぐために、この簡単なコードを作成しました:

if ((strpos($_SERVER['HTTP_REFERER'],'www.domain.com')!==0)) {
    $redirect='index.php';
    header("Location: $redirect");
    exit;
}

wbesite 内のリンクをクリックしても、常に index.php にリダイレクトされます。ドメインを次のような多くのタイプに変更しようとしました:

http://www.domain.com
www.domain.com
domain.com
ドメイン

しかし、それでも同じ問題

4

2 に答える 2

4

解決策を見つけました。HTTP_REFERERHTTP_HOSTusing を比較strposしました。一致する場合は、ホットリンクがないことを意味します。コード :

if($_SERVER['HTTP_REFERER'])
   {
      if(!strpos($_SERVER['HTTP_REFERER'],$_SERVER['HTTP_HOST']))
         {
            $redirect='index.php';
            header("場所: $redirect");
         }
   }
于 2012-11-07T03:00:47.663 に答える
1

あなたは実際に!== FALSE代わりに使いたいです。文字列は位置にある可能性があります0。zerkms の提案も含めます。

if (!empty($_SERVER['HTTP_REFERER']) && 
    (strpos($_SERVER['HTTP_REFERER'],'www.domain.com') !== FALSE)) {

ドキュメント: http://php.net/manual/en/function.strpos.php

于 2012-11-07T02:44:19.723 に答える