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

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

WebStorm Mac版
好用的JavaScript开发工具

Atom编辑器mac版下载
最流行的的开源编辑器

Dreamweaver Mac版
视觉化网页开发工具