Maison > Article > développement back-end > Introduction à la méthode d'obtention de la véritable IP du vrai client en PHP
REMOTE_ADDR est l'adresse IP lorsque votre client « établit une poignée de main » avec votre serveur. Si un "proxy anonyme" est utilisé, REMOTE_ADDR affichera l'IP du serveur proxy.
HTTP_CLIENT_IP est l'en-tête HTTP envoyé par le serveur proxy. S'il s'agit d'un "proxy super anonyme", la valeur "none" est renvoyée. De même, REMOTE_ADDR sera remplacé par l'IP de ce serveur proxy.
$_SERVER['REMOTE_ADDR']; //Fin d'accès (peut être un utilisateur, peut être un proxy) IP
$_SERVER['HTTP_CLIENT_IP'] //Fin du proxy (il peut exister) et peut être falsifié)
$_SERVER['HTTP_X_FORWARDED_FOR']; //Quelle adresse IP l'utilisateur utilise comme proxy (elle peut exister et elle peut également être falsifiée)
La différence entre les trois valeurs est la suivante :
1. Lorsqu'aucun serveur proxy n'est utilisé :
REMOTE_ADDR = votre IP
HTTP_VIA = Aucune valeur ou non affichée
HTTP_X_FORWARDED_FOR = Aucune valeur ou non affichée
2 Lors de l'utilisation de serveurs proxy transparents : Proxies transparents
REMOTE_ADDR = Dernière IP du serveur proxy
HTTP_VIA = IP du serveur proxy
HTTP_X_FORWARDED_FOR = votre véritable IP Lors du passage par plusieurs serveurs proxy, cette valeur est similaire à la suivante : 203.98.182.163, 203.98.182.163, 203.129.72.215.
Ce type de serveur proxy transmet toujours vos informations à la personne que vous visitez et ne peut pas atteindre l'objectif de cacher votre véritable identité.
3. La situation d'utilisation de serveurs proxy anonymes ordinaires : Proxies anonymes
REMOTE_ADDR = Dernière IP du serveur proxy
HTTP_VIA = IP du serveur proxy
HTTP_X_FORWARDED_FOR = IP du serveur proxy, lors du passage via plusieurs serveurs proxy, cette valeur est similaire à la suivante : 203.98.182.163, 203.98.182.163, 203.129.72.215.
Cachez votre véritable IP, mais révélez à vos visiteurs que vous utilisez un serveur proxy pour y accéder.
4. L'utilisation de serveurs proxy trompeurs : Proxy déformants
REMOTE_ADDR = IP du serveur proxy
HTTP_VIA = IP du serveur proxy
HTTP_X_FORWARDED_FOR = IP aléatoire, lors du passage via plusieurs serveurs proxy, cette valeur est similaire à la suivante : 203.98.182.163, 203.98.182.163, 203.129.72.215.
Dites au visiteur que vous utilisez un serveur proxy, mais inventez une fausse adresse IP aléatoire au lieu de votre véritable adresse IP pour le tromper.
5. Lors de l'utilisation de serveurs proxy à haut anonymat : proxys à haut anonymat (proxys Elite)
REMOTE_ADDR = IP du serveur proxy
HTTP_VIA = Aucune valeur ou non affiché
HTTP_X_FORWARDED_FOR = Aucune valeur ou non affiché. Lors du passage via plusieurs serveurs proxy, la valeur est similaire à la suivante : 203.98.182.163, 203.98.182.163, 203.129.72.215.
Remplace complètement toutes vos informations par celles du serveur proxy, tout comme vous utilisez ce serveur proxy pour accéder directement à l'objet.
//获取用户IP $ip = ''; foreach (array('HTTP_CLIENT_IP', 'HTTP_X_FORWARDED_FOR', 'HTTP_FROM', 'REMOTE_ADDR') as $v) { if (isset($_SERVER[$v])) { if (! preg_match('/^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$/', $_SERVER[$v])) { continue; } $ip = $_SERVER[$v]; } } uset($ip,$v);
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!