
1 fatpa Apr 17, 2014 去 header 里面取 |
2 XadillaX Apr 17, 2014 去header里面取,有多种可能。如果是nginx反向代理,大家约定俗成的是X-Forwarded-For,如果是CloudFlare的话,是CF-Connecting-IP。等等等等。 自己写几个if判断下就好了。 |
3 raincious 这信息不会告诉你的。执行程序机器的IP在CDN网络中就算出于安全考虑也不会泄露出来,这也是分发网络的意义。 除非你在Header上标注好,比如header('X-Processor: ' . gethostname() . ': ' . $_SERVER['SERVER_ADDR']); 但是如果是别人的程序,别想了,人家就是为了隐藏真实IP才这么做的。 当然,如果对方的网站会使用其他服务,那么可以通过那个得到真实的IP地址,比如查网站发出的邮件,看源信,里面会有服务器的公网IP地址。 |
4 wdlth Apr 17, 2014 这种问法本身就很奇怪,你要获取别人网站后端的IP?你怎么知道别人是不是集群,有没有缓存,有没有负载均衡,是公网IP还是内网IP。就像各种Appengine,都是集群的,你不会知道下次是哪台机去执行。 |
5 babytomas OP |
7 raincious Apr 17, 2014 好吧,我真的不明白这个问题了。可能我一开始就没看清。 如果你是要求得到访问客户端的IP地址,那么2楼的答复就是对的。各个CDN的约定不一样,只能用IF搞定,没有通用方式。 X-Forwarded-For是一种不安全的方式,需要另外配置来保证安全。原理是自己维护一个受信IP地址列表,然后从最后一台转发请求的服务器开始搜索,看服务器是否在受信列表里,如果不在则认为IP地址是客户端的地址。 我自己有一个粗糙的实现方法,在https://github.com/raincious/facula/blob/master/src/Facula/Base/Prototype/Core/Request.php#L494 配置文件就像这样: https://github.com/raincious/facula/blob/master/examples/BasicStart/privated/Configurations/Primary.php#L82 如果你是想得到真正执行PHP程序然后返回给客户端的那台服务器的IP地址,3楼我的答案是对的。 |
11 konakona Apr 18, 2014 http://blog.crazyphper.com/?p=1753 我这里写的很清楚。 |
12 loveminds Jan 16, 2015 via iPhone 如果你能上传php文件到这个后端,很简单,curl一下 |