


Explication détaillée d'exemples de méthodes pour empêcher les hotlinking en PHP
May 19, 2018 am 09:24 AMCet article présente principalement la méthode d'anti-hotlinking en PHP, et analyse les technologies associées et les techniques de mise en œuvre spécifiques impliquées dans l'anti-hotlinking PHP sous forme d'exemples. Les amis dans le besoin peuvent se référer à
Le. les détails sont les suivants :
$_SERVER['HTTP_REFERER']
statut d'acquisition
Remarque $_SERVER['HTTP_REFERER'] ne peut pas toujours être obtenu Il ne peut être obtenu que sous les conditions suivantes. circonstances :
1. Les situations dans lesquelles HTTP_REFERER peut être obtenu sont les suivantes :
1. Utilisez directement <a href>
2. Formulaire soumis avec Soumettre ou <input type=image> (POST ou GET)
3. Formulaires soumis en utilisant Jscript (POST ou GET)
2. Les situations suivantes ne peuvent pas être obtenues :
1. Lien des favoris
2. Cliquez sur "Accueil" ou sur l'adresse personnalisée
3. Utilisez location.href ou location.replace()
4 de Jscript. Saisissez l'adresse directement dans le navigateur
5. <%Response.Redirect%>
6. <%Response.AddHeader%> ou <meta http-equiv=refresh> rediriger vers
7. Charger l'adresse avec XML
strrpos
Explication de la fonction :
strrpos — Calcule la position de la dernière occurrence de la chaîne spécifiée dans la chaîne cible
Explication
int strrpos ( string $haystack , string $needle [, int $offset = 0 ] )<code>int strrpos ( string $haystack , string $needle [, int $offset = 0 ] )<br>
Renvoie la position numérique de la dernière occurrence de l'aiguille dans la chaîne $ meule de foin.
$haystack | 在此字符串中进行查找。 |
$needle | 如果 needle不是一个字符串,它将被转换为整型并被视为字符的顺序值。 |
Valeur de retour
Renvoie la position où l'aiguille existe. S'il n'est pas trouvé, renvoie FALSE.
Code de détection de lien chaud : asd.php
<?php //防盗链技术 //先判断是否获取到 $_SERVER['HTTP_REFERER'] 变量 if(isset($_SERVER['HTTP_REFERER'])){ //判断$_SERVER['HTTP_REFERER']是不是以http://localhost/开始的 if(strpos($_SERVER['HTTP_REFERER'],"http://localhost")==0){ echo '<img src="a.png"/>'; } else{ header("Location:warning.php");//跳转页面到warning.php //echo $_SERVER["HTTP_REFERER"]; } } else { header("Location:warning.php"); } ?>
warning.php
<html> <b>倒链</b> </html>
Code de vérification anti-hotlink
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> </head> <body> <a href="http://localhost/wml/asd.php" rel="external nofollow" >验证防盗链</a> </body> </html>
Ce qui précède est pour comprendre le principe
Généralement, en configurant le serveur pour empêcher les hotlinking, comme l'accès à la configuration nginx
(gif|jpg|jpeg|png|bmp|swf) et la liste blanche d'autres fichiers
Le une configuration spécifique peut être recherchée sur Baidu
Recommandations associées :
NginxAnti-hotlinking et contrôle d'accès Nginx et configuration php d'analyse Nginx
Comment implémenter PHPAnti-hotlinkingExplication détaillée
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian

Comment configurer Visual Studio Code (VS Code) pour le développement PHP
