핫링크란 서비스 제공자 자체가 서비스를 제공하지 않는 콘텐츠를 말하며, 기술적 수단을 사용하여 최종 사용자에게 유익한 다른 인터페이스(예: 광고)를 우회하고 자체 웹사이트에서 다른 서비스 제공자의 서비스를 최종 사용자에게 직접 제공하는 것을 말합니다. . 최종 사용자의 탐색 및 클릭률을 속이는 콘텐츠. 수혜자는 자원을 전혀 또는 거의 제공하지 않는 반면, 실제 서비스 제공자는 아무런 혜택도 받지 못합니다. 핫링크를 방지하는 것은 모든 웹사이트 개발자에게 중요한 작업입니다.
핫링크를 효과적으로 방지하면 웹사이트 서버에 대한 부담을 크게 줄일 수 있습니다. 여기서는 PHP에서 핫링크 방지를 구현하는 방법을 공유합니다.
일반 다운로드 단계: 검색 -> 검색 결과 목록 출력 -> 소프트웨어 세부정보 페이지 입력 -> 다운로드 버튼 클릭 -> 다운로드 페이지 열기 -> 다운로드를 클릭하여 다운로드 시작
나의 방법은 다운로드 페이지에 글을 작성하는 것이다
먼저 웹사이트의 공개 파일에 $key=sdkfjwojf32413을 정의합니다. 이는 키와 동일합니다
다운로드 페이지에서 임의의 숫자 생성: $certcode = '84615354' (열 때마다 생성된 숫자가 다름)
그런 다음 위의 두 변수와 소프트웨어 ID를 사용하여 md5() 암호화 문자열을 생성합니다
그런 다음 소프트웨어의 실제 다운로드 주소를 생성합니다: file.php?id=5&codekey=ksfjwofsdkfsf
여기서 ID는 소프트웨어의 번호입니다. $codekey=md5($id.$certcode.$key)
를 기반으로 데이터베이스에서 소프트웨어 주소를 찾을 수 있습니다.
그런 다음 인증서 코드를 세션에 저장하세요.
file.php의 매개변수에서 코드키와 ID를 가져온 다음 공개 파일에서 $key를 가져온 다음 세션에서 $certcode를 가져옵니다
코드키가 맞는지 확인해보세요. 틀리면 종료하고, 아니면 다음과 같이 진행하세요
1. 세션 삭제(이 주소를 다시 열면 무효화됩니다)
2. 데이터베이스에서 소프트웨어 주소를 읽은 후 소프트웨어 내용을 읽고 출력합니다. (다운로드할 주소를 직접 제공하는 대신 PHP의 파일 읽기 방법을 사용하여 다운로드할 소프트웨어 내용을 출력합니다.)
다운로드를 원하시면 반드시 본인의 다운로드 페이지를 열어서 다운로드 페이지에서 주소를 열어서 다운로드하셔야 하며, 생성되는 난수가 다르기 때문에 다운로드 주소는 매번 다릅니다
다운로드 주소가 다른 곳에 연결되어 있어도 다운로드가 불가능합니다.
확장 읽기(구체적 구현):
1. 단순 안티리칭
$ADMIN[defaulturl] = "http://www.vvschool.cn/404.htm";//盗链返回的地址 $okaysites = array("http://www.vvschool.cn/","http://www.siyizhu.com"); //白名单 $ADMIN[url_1] = "http://www.vvschool.cn/temp/download/";//下载地点1 $ADMIN[url_2] = "";//下载地点2,以此类推 $reffer = $HTTP_REFERER; if($reffer) { $yes = 0; while(list($domain, $subarray) = each($okaysites)) { if (ereg($subarray,"$reffer")) { $yes = 1; } } $theu = "url"."_"."$site"; if ($ADMIN[$theu] AND $yes == 1) { header("Location: $ADMIN[$theu]/$file"); } else { header("Location: $ADMIN[defaulturl]"); } } else { header("Location: $ADMIN[defaulturl]"); }?>
사용방법: 위의 코드를 dao4.php로 저장합니다. 예를 들어 제가 테스트에 사용한 verifycode.rar이 내 사이트에 있다면, 다운로드 링크를 표현하기 위해 다음 코드를 사용합니다.
파일 이름?site=1&file=file
2. 서버 핫링크 방지
3. 소프트웨어 다운로드 방지 방법
//放置下载软件的根目录相对于当前脚本目录的相对目录 $fileRelPath = "../../software"; //例外允许连接的网址,注意:自身域名不需要填入,设定为肯定可以下载, // 空字符串("")表示直接输入网址下载的情况 $excludeReferArr = array("www.wreny.com", "wreny.com"); chdir($fileRelPath); $fileRootPath = getcwd() ."/"; $filePath=$HTTP_GET_VARS["file"]; $url=parse_url($_SERVER["HTTP_REFERER"]); if($url[host]!=$_SERVER["HTTP_HOST"] && !in_array($referHost, $excludeReferArr)){ ?>
사실, 거머리 방지 방법에는 여러 가지가 있습니다. 참고할 수 있는 일반적인 아이디어는 다음과 같습니다.
(1) ISAPI_Rewrite를 사용하는 IIS 안티-리칭은 Windows에서 안티-리칭에 대한 솔루션으로 사용될 수 있습니다.
(2) 사진 핫링크 방지, 사진에 워터마크 추가 핫링커는 목표를 달성할 수 있지만 자신의 웹사이트를 홍보하기도 합니다.위 내용은 PHP 안티 핫링크의 기본 아이디어와 설정 방법입니다. 모든 분들의 학습에 도움이 되기를 바랍니다.