Maison >développement back-end >tutoriel php >Quelle variable PHP $_SERVER est la meilleure pour les définitions de liens de sites Web : HTTP_HOST ou SERVER_NAME ?
Comprendre PHP $_SERVER['HTTP_HOST'] et $_SERVER['SERVER_NAME']
Déterminer la variable de serveur correcte à utiliser pour le site Web les définitions de liens soulèvent des inquiétudes. La documentation PHP et des recherches approfondies en ligne conduisent aux informations suivantes :
**$_SERVER['HTTP_HOST'] vs. **_$SERVER['SERVER_NAME']
$_SERVER['SERVER_NAME'] repose sur la configuration du serveur Web (généralement Apache2) et est influencé par des directives telles que VirtualHost, ServerName et UseCanonicalName.
À l'inverse, $_SERVER['HTTP_HOST'] est dérivé de la demande du client.
Choisir la variable appropriée
En fonction de ces différences, $_SERVER[ 'HTTP_HOST'] semble être plus approprié pour garantir la compatibilité entre différents environnements. Cependant, des inquiétudes proviennent d'articles suggérant le manque de fiabilité des variables $_SERVER dans des contextes de sécurité.
Considérations sur la sécurité
La documentation PHP et les références telles que l'article de Mark Jaquith mettent en évidence le potentiel pour les attaques XSS lors de l'utilisation de $_SERVER['PHP_SELF'] dans des actions de formulaire sans nettoyage approprié. Cependant, ce problème ne s'applique pas directement à $_SERVER['HTTP_HOST'].
Conclusion
Bien que $_SERVER['HTTP_HOST'] réponde aux soucis de compatibilité, il est important de faire preuve de prudence en mettant en œuvre des mesures de sécurité telles que :
En prenant ces mesures, vous pouvez garantir l'utilisation sécurisée et fiable des variables PHP $_SERVER dans le fichier de votre site Web. définitions de liens.
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!