通过PHP实现获取访问用户IP
在php中自带了一个非常的简单的获取IP地址的全局变量,很多初学都获取IP都使用它了,但是对于这些我们一般用法是满足了,但是对于要求高精度这个函数还是不行的。
这个是最简单的方法,对于开了透明代理之类的是没有办法的,如果内网访问也不能读取正确的外网IP,不过很省力就是了:
$ip = $_SERVER["REMOTE_ADDR"];
搞定~
上面方法用来取得客户端的 IP 地址,但如果客户端是使用代理服务器来访问,那取到的就是代理服务器的 IP 地址,而不是真正的客户端 IP 地址
要想透过代理服务器取得客户端的真实 IP 地址,就要使用 getenv("HTTP_X_FORWARDED_FOR") 来读取。
但是如果客户端没有通过代理服务器来访问,那么用getenv("HTTP_X_FORWARDED_FOR") 取到的值将是空的。
else if(getenv("HTTP_X_FORWARDED_FOR"))
$ip = getenv("HTTP_X_FORWARDED_FOR");
表示如果getenv("HTTP_X_FORWARDED_FOR") 取到的值存在不为空(即客户端使用代理服务器的情况下),则变量$ip等于getenv("HTTP_X_FORWARDED_FOR") 取到的真实IP值。
如果上面的else if(getenv("HTTP_X_FORWARDED_FOR"))取得的值为空(即没有使用代理服务器),则不会执行下面的$ip = getenv("HTTP_X_FORWARDED_FOR");这一行语句。
这种情况下已经确认客户端没有使用代理服务器,从而通过
else if(getenv("REMOTE_ADDR"))
$ip = getenv("REMOTE_ADDR");
这两行语句获得客户端的IP地址也是真实的IP地址,根据经验得出
?1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | function getIP() { static $realip ; if (isset( $_SERVER )){ if (isset( $_SERVER [ "HTTP_X_FORWARDED_FOR" ])){ $realip = $_SERVER [ "HTTP_X_FORWARDED_FOR" ]; } else if (isset( $_SERVER [ "HTTP_CLIENT_IP" ])) { $realip = $_SERVER [ "HTTP_CLIENT_IP" ]; } else { $realip = $_SERVER [ "REMOTE_ADDR" ]; } } else { if ( getenv ( "HTTP_X_FORWARDED_FOR" )){ $realip = getenv ( "HTTP_X_FORWARDED_FOR" ); } else if ( getenv ( "HTTP_CLIENT_IP" )) { $realip = getenv ( "HTTP_CLIENT_IP" ); } else { $realip = getenv ( "REMOTE_ADDR" ); } } return $realip ; } |
另外如果我们想获取更精准的使用第三方是一个不错的方法哦
?1 2 3 4 5 6 7 | function get_onlineip() { $ch = curl_init( 'http://www.ip138.com/ip2city.asp' ); curl_setopt( $ch , CURLOPT_RETURNTRANSFER, true); $a = curl_exec( $ch ); preg_match( '/[(.*)]/' , $a , $ip ); return $ip [1]; } |
这样不管理代理还是什么都可以判断IP地址哦
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://www.cnblogs.com/forforever/p/12674056.html
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。