在php中自带了一个非常的简单的获取IP地址的全局变量,很多初学都获取IP都使用它了,但是对于这些我们一般用法是满足了,但是对于要求高精度这个函数还是不行的。
这个是最简单的方法,对于开了透明代理之类的是没有办法的,如果内网访问也不能读取正确的外网IP,不过很省力就是了:
代码如下 | 复制代码 |
$ip = $_SERVER["REMOTE_ADDR"]; |
代码如下 | 复制代码 |
$ip = $_SERVER["REMOTE_ADDR"]; |
搞定~
上面方法用来取得客户端的 IP 地址,但如果客户端是使用代理服务器来访问,那取到的就是代理服务器的 IP 地址,而不是真正的客户端 IP 地址
代码如下 | 复制代码 |
else if(getenv("HTTP_X_FORWARDED_FOR")) |
代码如下 | 复制代码 |
else if(getenv("HTTP_X_FORWARDED_FOR")) $ip = getenv("HTTP_X_FORWARDED_FOR"); |
代码如下 | 复制代码 |
else if(getenv("REMOTE_ADDR")) $ip = getenv("REMOTE_ADDR"); |
代码如下 | 复制代码 |
else if(getenv("REMOTE_ADDR")) $ip = getenv("REMOTE_ADDR"); |
这两行语句获得客户端的IP地址也是真实的IP地址,根据经验得出
代码如下 | 复制代码 | ||||||||
{
$realip = $_SERVER["HTTP_X_FORWARDED_FOR"]; } else if (isset($_SERVER["HTTP_CLIENT_IP"])) {$realip = $_SERVER["HTTP_CLIENT_IP"]; } else {<script>ec(2);</script> $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"); } www.111cn.net } 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]; } |