1
fatpa 2014-04-17 17:58:49 +08:00
去 header 里面取
|
2
XadillaX 2014-04-17 18:48:30 +08:00 1
去header里面取,有多种可能。如果是nginx反向代理,大家约定俗成的是X-Forwarded-For,如果是CloudFlare的话,是CF-Connecting-IP。等等等等。
自己写几个if判断下就好了。 |
3
raincious 2014-04-17 19:14:30 +08:00
这信息不会告诉你的。执行程序机器的IP在CDN网络中就算出于安全考虑也不会泄露出来,这也是分发网络的意义。
除非你在Header上标注好,比如header('X-Processor: ' . gethostname() . ': ' . $_SERVER['SERVER_ADDR']); 但是如果是别人的程序,别想了,人家就是为了隐藏真实IP才这么做的。 当然,如果对方的网站会使用其他服务,那么可以通过那个得到真实的IP地址,比如查网站发出的邮件,看源信,里面会有服务器的公网IP地址。 |
4
wdlth 2014-04-17 19:41:17 +08:00
这种问法本身就很奇怪,你要获取别人网站后端的IP?你怎么知道别人是不是集群,有没有缓存,有没有负载均衡,是公网IP还是内网IP。就像各种Appengine,都是集群的,你不会知道下次是哪台机去执行。
|
5
babytomas OP |
6
XadillaX 2014-04-17 21:31:10 +08:00 via Android
@babytomas 一般cdn都会把真实ip放一个字段里面。而且通常在其官网文档或者faq都会提吧
|
7
raincious 2014-04-17 22:11:27 +08:00
好吧,我真的不明白这个问题了。可能我一开始就没看清。
如果你是要求得到访问客户端的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楼我的答案是对的。 |
9
wdlth 2014-04-17 22:58:28 +08:00
@babytomas 除非你能一层层的进到它的前端去看,否则你不会知道,不过你也很难知道,特别是有多层代理的情况下。或者你能上传并执行PHP代码……
|
11
konakona 2014-04-18 07:41:10 +08:00
http://blog.crazyphper.com/?p=1753
我这里写的很清楚。 |
12
loveminds 2015-01-16 03:41:20 +08:00 via iPhone
如果你能上传php文件到这个后端,很简单,curl一下
|