unknown怎么处理全⾯解析:怎么查贴吧微博匿名帖⼦IP地址到发帖⼈是谁?
全⾯解析:怎么查贴吧微博匿名帖⼦IP地址到发帖⼈是谁?
随着社会的bai发展,现在的电脑已经被越来越多的du家庭所接受。zhi⽹络也逐步⾛进我们的⽣活,
⼈们已dao经习惯在⽹上了解更多的信息,包括学习。从⽹络带给我们便 利到现在的不可缺少,⽹络已经成了我们⼤多数⼈⽣活不可或缺的⼀部分,有⼈利⽤⽹络买卖,有⼈利⽤⽹络学习,,,但也有⼈利⽤⽹络来诋毁他⼈。
最近⽼有⼈问我,如何通过帖⼦到匿名发贴⼈的详细信息
PHP获取客户端IP的情况分为:没有使⽤代理服务器的情况、使⽤透明代理服务器的情况、使⽤普bai通匿名代理服务器的情况、使⽤欺骗性代理服务器的情况、使⽤⾼匿名代理服务器的情况。
在这篇⽂章中,我们将会为⼤家详细介绍PHP获取客户端IP的⼏种情况分析。我们在使⽤PHP获取的IP可能是客户端真实的IP,也可能是代理服务器的IP,也有可能根本取不到任何IP值。
在PHP获取客户端IP中常使⽤ $_SERVER["REMOTE_ADDR"] 。但如果客户端是使⽤代理服务器来访问,那取到的是代理服务器的 IP 地址,⽽不是真正的客户端 IP 地址。要想透过代理服务器取得客户端的真实 IP 地址,就要使⽤ $_SERVER["HTTP_X_FORWARDED_FOR"] 来读取。
但只有客户端使⽤“透明代理”的情况下,$_SERVER["HTTP_X_FORWARDED_FOR"] 的值才是客户端真正的IP(如果是多层代理,该值可能是由客户端真正IP和多个代理服务器的IP组成,由逗号“,”分隔),⽽在“匿名代理”、“欺骗性代理”的情况下是代理服务器的IP值(如果是多层代理,该值可能由多个代理服务器的IP组成,由逗号“,”分隔),在“⾼匿名代理”的情况下是空值。
关于HTTP头信息中的REMOTE_ADDR、HTTP_FORWARDED_FOR值,我们在下⽂中有详细的介绍,假设客户端真实IP是221.5.252.160:
作者0Q0:
  六年专业查询天涯百度论坛博客等发帖⼈IP地址
⼀、没有使⽤代理服务器的PHP获取客户端IP情况:
REMOTE_ADDR = 客户端IP
HTTP_X_FORWARDED_FOR = 没数值或不显⽰
⼆、使⽤透明代理服务器的情况:Transparent Proxies
REMOTE_ADDR = 最后⼀个代理服务器 IP
HTTP_X_FORWARDED_FOR = 客户端真实 IP (经过多个代理服务器时,这个值类似:221.5.252.160, 203.98.182.163,
203.129.72.215)
这类代理服务器还是将客户端真实的IP发送给了访问对象,⽆法达到隐藏真实⾝份的⽬的。
三、使⽤普通匿名代理服务器的PHP获取客户端IP情况:Anonymous Proxies
REMOTE_ADDR = 最后⼀个代理服务器 IP
HTTP_X_FORWARDED_FOR = 代理服务器 IP (经过多个代理服务器时,这个值类似:203.98.182.163, 203.98.182.163,
203.129.72.215)
这种情况下隐藏了客户端的真实IP,但是向访问对象透露了客户端是使⽤代理服务器访问它们的。
四、使⽤欺骗性代理服务器的情况:Distorting Proxies
REMOTE_ADDR = 代理服务器 IP
HTTP_X_FORWARDED_FOR = 随机的 IP(经过多个代理服务器时,这个值类似:220.4.251.159, 203.98.182.163, 203.129.72.215)
这种情况下同样透露了客户端是使⽤了代理服务器,但编造了⼀个虚假的随机IP(220.4.251.159)代替客户端的真实IP来欺骗它。
五、使⽤⾼匿名代理服务器的PHP获取客户端IP情况:High Anonymity Proxies (Elite proxies)
REMOTE_ADDR = 代理服务器 IP
HTTP_X_FORWARDED_FOR = 没数值或不显⽰
⽆论是REMOTE_ADDR还是HTTP_FORWARDED_FOR,这些头消息未必能够取得到,因为不同的浏览器不同的⽹络设备可能发送不同的IP头消息。因此PHP使⽤$_SERVER["REMOTE_ADDR"] 、$_SERVER["HTTP_X_FORWARDED_FOR"] 获取的值可能是空值也可能
是“unknown”值。
因此,使⽤PHP获取客户端IP的代码可以如下:
view plaincopy to clipboardprint?
function getip() {
$unknown = 'unknown';
if ( isset($_SERVER['HTTP_X_FORWARDED_FOR']) && $_SERVER['HTTP_X_FORWARDED_FOR'] &&
strcasecmp($_SERVER['HTTP_X_FORWARDED_FOR'], $unknown) ) {
$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
} elseif ( isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], $unknown) ) {
$ip = $_SERVER['REMOTE_ADDR'];
}
/*
处理多层代理的情况
或者使⽤正则⽅式:$ip = preg_match("/[\d\.]{7,15}/", $ip, $matches) ? $matches[0] : $unknown;
*/
if (false !== strpos($ip, ','))
$ip = reset(explode(',', $ip));
return $ip;
}
function getip() {
$unknown = 'unknown';
if ( isset($_SERVER['HTTP_X_FORWARDED_FOR']) && $_SERVER['HTTP_X_FORWARDED_FOR'] &&
strcasecmp($_SERVER['HTTP_X_FORWARDED_FOR'], $unknown) ) {
$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
} elseif ( isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], $unknown) ) {
$ip = $_SERVER['REMOTE_ADDR'];
}
/*
处理多层代理的情况
或者使⽤正则⽅式:$ip = preg_match("/[\d\.]{7,15}/", $ip, $matches) ? $matches[0] : $unknown;
*/
if (false !== strpos($ip, ','))
$ip = reset(explode(',', $ip));
return $ip;
}
PHP获取客户端IP时另外⼀点需注意,使⽤函数getenv(’HTTP_X_FORWARDED_FOR’)或getenv(’REMOTE_ADDR’) 也可以如上代码⼀样取得同样的效果。但getenv()不⽀持在IIS的isapi⽅式下运⾏的PHP。
全⾯解析:怎么查贴吧微博匿名帖⼦IP地址到发帖⼈是谁?

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。