Maison >développement back-end >tutoriel php >Comment utiliser PHP pour obtenir la véritable adresse IP du client utilisateur

Comment utiliser PHP pour obtenir la véritable adresse IP du client utilisateur

不言
不言original
2018-06-08 09:35:502919parcourir

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é


2. Le cas de l'utilisation d'un serveur proxy transparent : Transparent Proxies

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é.

3. Utilisez PHP d'un serveur proxy anonyme ordinaire pour obtenir l'adresse IP du client : Proxies anonymes

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.

4. L'utilisation de serveurs proxy trompeurs : proxys déformants

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

5. Utiliser PHP d'un serveur proxy à haut anonymat pour obtenir le serveur proxy. IP du client : Proxies à anonymat élevé (proxys Elite)

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 PHP


PHP obtient les informations IP, php obtient l'IP

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn