• 技术文章 >后端开发 >PHP问题

    php怎么识别真实ip

    (*-*)浩(*-*)浩2019-09-12 11:06:15原创64
    PHP 里用来获取客户端 IP 的变量有这些:

    $_SERVER['HTTP_CLIENT_IP'] 这个头是有的,但是很少,不一定服务器都实现了。客户端可以伪造。(推荐学习:PHP编程从入门到精通

    $_SERVER['HTTP_X_FORWARDED_FOR'] 是有标准定义,用来识别经过 HTTP 代理后的客户端 IP 地址,格式:clientip,proxy1,proxy2。详细解释见 http://zh.wikipedia.org/wiki/X-Forwarded-F...。 客户端可以伪造。

    $_SERVER['REMOTE_ADDR'] 是可靠的, 它是最后一个跟你的服务器握手的 IP,可能是用户的代理服务器,也可能是自己的反向代理。客户端不能伪造。

    客户端可以伪造的参数必须过滤和验证!很多人以为 $_SERVER 变量里的东西都是可信的,其实并不不然,$_SERVER['HTTP_CLIENT_IP'] 和 $_SERVER['HTTP_X_FORWARDED_FOR'] 都来自客户端请求的 header 里面。

    如果要严格获取用户真实 ip

    在反爬虫,防刷票的时候,客户端可以伪造的东西,我们一律不信任,此为严格获取。

    没有套 CDN,用户直连我们的 PHP 服务器

    这种情况下用 tcp 层握手的 ip,$_SERVER['REMOTE_ADDR']

    自建集群用 nginx 实现负载均衡的时候

    这种情况下,PHP 应用服务器不能对外暴露,我们在 nginx 中实现获取真实 IP 再换发给 PHP 服务器。

    location /{
       proxy_set_header client-real-ip $remote_addr;
    }

    client-real-ip 可以随意自己命名,我们将 tcp 层中跟 nginx 握手的 ip 转发给 PHP。

    使用 CDN,从 PHP 服务器取源的时候

    CDN 会转发客户端的握手 ip 过来,各家策略有差异,具体去查 CDN 的文档。

    当然我们也可以把需要严格核查的业务绑一个二级域名,单独走我们自己的 nginx 服务器,避开 CDN。

    以上就是php怎么识别真实ip的详细内容,更多请关注php中文网其它相关文章!

    phpstudy集成环境下载
    本文原创发布php中文网,转载请注明出处,感谢您的尊重!
    专题推荐:php
    上一篇:php怎么实现多态 下一篇:php怎么确保统计的数据正确

    相关文章推荐

    • 宝塔安装php不显示• 宝塔phpmyadmin无法打开• 百度站长主动推送php怎么弄• 高级php开发掌握哪些技能

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网