这篇文章主要介绍php无法获取真实ip怎么办,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
<强>一、获取用户真实ip地址强>
公共静态函数getClientIp () { 如果采用(& # 39;HTTP_CLIENT_IP& # 39;)) { $ ip=getenv (& # 39; HTTP_CLIENT_IP& # 39;); } 如果采用(& # 39;HTTP_X_REAL_IP& # 39;)) { $ ip=getenv (& # 39; HTTP_X_REAL_IP& # 39;); 采用}elseif & # 39; HTTP_X_FORWARDED_FOR& # 39;)) { $ ip=getenv (& # 39; HTTP_X_FORWARDED_FOR& # 39;); ips美元=爆炸(& # 39;& # 39;$ ip); ip=ips美元[0]; 采用}elseif & # 39; REMOTE_ADDR& # 39;)) { $ ip=getenv (& # 39; REMOTE_ADDR& # 39;); 其他}{ $ ip=& # 39; 0.0.0.0 # 39;; } 返回$ ip; }
<>强注意:强>
$ _SERVER和采用的区别,采用不支持IIS的isapi方式运行的php.getenv (REMOTE_ADDR)函数在apache下能正常获取ip地址,而在IIS中没有作用,而$ _SERVER [& # 39; REMOTE_ADDR& # 39;]函数,既可在apache中成功获取访客的ip地址,在IIS下也同样有效。
<强>二、关于REMOTE_ADDR 强>
这个变量获取到的是《直接来源》的ip地址,所谓《直接来源》指的是直接请求该地址的客户端ip。这个ip在单服务器的情况下,很准确的是客户端ip,无法伪造。当然并不是所有的程序都一定是单服务器,比如在采用负载均衡的情况(比如采用haproxy或者nginx进行负载均衡),这个ip就是转发机器的ip,因为过程是客户端→负载均衡→服务端。是由负载均衡直接访问的服务端而不是客户端。
<强>三、关于HTTP_X_FORWARDED_FOR和HTTP_CLIENT_IP 强>
在负载均衡的情况下直接使用REMOTE_ADDR是无法获取客户端ip的,这就是一个问题,必须解决。于是就衍生出了负载均衡端将客户端ip加入到头部中发送给服务端,让服务端可以获取到客户端的真实ip。当然也就产生了各位所说的伪造,毕竟头除了协议里固定的那几个数据,其他数据都是可自定义的。
以上是php无法获取真实ip怎么办的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!