Maison >développement back-end >tutoriel php >Comment utiliser PHP pour obtenir la véritable adresse IP du client utilisateur
Cet article présente principalement la méthode d'utilisation de PHP pour obtenir la véritable adresse IP du client de l'utilisateur. Il a une certaine valeur de référence. Maintenant, je le partage avec vous. Les amis dans le besoin peuvent s'y référer
En fait, obtenir l'adresse IP du client Ce n'est pas une tâche simple. En raison de problèmes d'usurpation d'adresse IP et d'agence, l'authenticité de l'obtention de l'adresse IP du client sera compromise et ne pourra pas être exacte à 100 %. Cependant, nous essayons d'utiliser des méthodes plus complètes pour obtenir l'adresse IP du client. . Voici ce qui suit Partagez la méthode pour obtenir l'adresse IP réelle du client de l'utilisateur en PHP, jetons un coup d'oeil
L'obtention de l'adresse IP du client n'est en fait pas une tâche simple, car il y a des problèmes d'usurpation d'adresse IP et de proxy, donc obtenir l'authenticité de l'adresse IP du client sera actualisée et ne peut pas être exacte à 100 %. Mais nous essayons toujours de trouver une méthode plus complète pour obtenir la véritable adresse IP du client. Il existe de nombreuses façons d'obtenir l'adresse IP en utilisant php. 🎜>
function getIp(){ if (getenv("HTTP_CLIENT_IP") && strcasecmp(getenv("HTTP_CLIENT_IP"), "unknown")) $ip = getenv("HTTP_CLIENT_IP"); else if (getenv("HTTP_X_FORWARDED_FOR") && strcasecmp(getenv("HTTP_X_FORWARDED_FOR"), "unknown")) $ip = getenv("HTTP_X_FORWARDED_FOR"); else if (getenv("REMOTE_ADDR") && strcasecmp(getenv("REMOTE_ADDR"), "unknown")) $ip = getenv("REMOTE_ADDR"); else if (isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], "unknown")) $ip = $_SERVER['REMOTE_ADDR']; else $ip = "unknown"; return($ip);Nous devons maintenant corriger ce paragraphe. Le code est expliqué. Deux fonctions sont utilisées ici, getenv() et strcasecmp(). La première fonction obtient la variable d'environnement système. il renvoie la valeur. Si ce n'est pas le cas, il renvoie false. $_SERVER est le tableau de super variables globales du serveur. Vous pouvez également utiliser $_SERVER['REMOTE_ADDR'] pour obtenir l'adresse IP du client. la deuxième est que getenv ne prend pas en charge php exécuté en mode isapi IIS. strcasecmp L'utilisation de la fonction de chaîne (string1, string2) consiste à comparer string1 et string2 si elles sont égales. string1 est supérieur à string2, un nombre supérieur à 0 est renvoyé. S'il est inférieur, un nombre inférieur à 0 est renvoyé. La fonction Utilisez d'abord l'adresse IP du client. Si cela ne fonctionne pas, essayez d'utiliser. la méthode proxy. Si cela ne fonctionne pas, utilisez REMOTE_ADDR. J'ai également vu une méthode plus détaillée de détection d'IP, qui prend en compte l'usurpation d'adresse IP et plusieurs codes proxy. 🎜>
function getip() { $unknown = 'unknown'; if ( isset($_SERVER['HTTP_X_FORWARDED_FOR']) && $_SERVER['HTTP_X_FORWARDED_FOR'] && strcasecmp($_SERVER['HTTP_X_FORWARDED_FOR'], $unknown) ) { $ip = $_SERVER['HTTP_X_FORWARDED_FOR']; } elseif ( isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], $unknown) ) { $ip = $_SERVER['REMOTE_ADDR']; } /* 处理多层代理的情况 或者使用正则方式:$ip = preg_match("/[\d\.]{7,15}/", $ip, $matches) ? $matches[0] : $unknown; */ if (false !== strpos($ip, ',')) $ip = reset(explode(',', $ip)); return $ip; }1. PHP sans serveur proxy pour obtenir l'IP du client :
REMOTE_ADDR = IP du client
HTTP_X_FORWARDED_FOR = Aucune valeur ou Non affichéREMOTE_ADDR = L'IP du dernier serveur proxy
HTTP_X_FORWARDED_FOR = La véritable IP du client (après plusieurs Lors de l'utilisation d'un proxy serveur, cette valeur est similaire : 221.5.252.160, 203.98.182.163, 203.129.72.215)
Ce type de serveur proxy envoie toujours la véritable adresse IP du client à l'objet d'accès et ne peut pas masquer la véritable identité.
REMOTE_ADDR = Dernière IP du serveur proxy
HTTP_X_FORWARDED_FOR = IP du serveur proxy (lorsque en passant par plusieurs serveurs proxy, cette valeur est similaire : 203.98.182.163, 203.98.182.163, 203.129.72.215)
Dans ce cas, la véritable IP du client est masquée, mais elle est exposée à l'objet d'accès Il est révélé que le client utilise un serveur proxy pour y accéder.
REMOTE_ADDR = serveur proxy IP
HTTP_X_FORWARDED_FOR = IP aléatoire (lors du passage par plusieurs serveurs proxy, cette valeur est similaire : 220.4.251.159, 203.98.182.163, 203.129.72.215)
Dans ce cas, cela révèle également que le client utilise un serveur proxy. Mais une fausse IP aléatoire (220.4.251.159) a été inventée pour remplacer la véritable IP du client afin de le tromper
REMOTE_ADDR = IP du serveur proxy
HTTP_X_FORWARDED_FOR = aucune valeur ou non affiché
Qu'il s'agisse de REMOTE_ADDR ou de HTTP_FORWARDED_FOR, ces messages d'en-tête peuvent ne pas être disponibles, car différents navigateurs et différents périphériques réseau peuvent envoyer différents messages d'en-tête IP. Par conséquent, la valeur obtenue par PHP en utilisant $_SERVER["REMOTE_ADDR"] et $_SERVER["HTTP_X_FORWARDED_FOR"] peut être une valeur nulle. ou une valeur "inconnue".
Ce qui précède est l'intégralité du contenu de cet article. J'espère qu'il sera utile à l'étude de tout le monde. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois !
Recommandations associées :
Comment implémenter l'anti-hotlinking en PHPPHP obtient les informations IP, php obtient l'IPCe 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!