加入收藏 | 设为首页 | 会员中心 | 我要投稿 河北网 (https://www.hebeiwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

通过PHP实现获取访问用户IP

发布时间:2020-05-10 20:22:55 所属栏目:编程 来源:站长网
导读:在php中自带了一个很是的简朴的获取IP地点的全局变量,许多初学都获取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地点,按照履历得出

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; }

其它假如我们想获取更精准的行使第三方是一个不错的要领哦

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地点哦

(编辑:河北网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读