整个函数是获取真实IP的,
function real_ip()
{
static $realip = NULL;
if ($realip !== NULL)
{
return $realip;
}
if (isset($_SERVER))
{
if (isset($_SERVER['HTTP_X_FORWARDED_FOR']))
{
$arr = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);
/* 取X-Forwarded-For中第一个非unknown的有效IP字符串 */
foreach ($arr AS $ip)
{
$ip = trim($ip);
if ($ip != 'unknown')
{
$realip = $ip;
break;
}
}
}
elseif (isset($_SERVER['HTTP_CLIENT_IP']))
{
$realip = $_SERVER['HTTP_CLIENT_IP'];
}
else
{
if (isset($_SERVER['REMOTE_ADDR']))
{
$realip = $_SERVER['REMOTE_ADDR'];
}
else
{
$realip = '0.0.0.0';
}
}
}
else
{
if (getenv('HTTP_X_FORWARDED_FOR'))
{
$realip = getenv('HTTP_X_FORWARDED_FOR');
}
elseif (getenv('HTTP_CLIENT_IP'))
{
$realip = getenv('HTTP_CLIENT_IP');
}
else
{
$realip = getenv('REMOTE_ADDR');
}
}
preg_match("/[\d\.]{7,15}/", $realip, $onlineip);
$realip = !empty($onlineip[0]) ? $onlineip[0] : '0.0.0.0';
return $realip;
}
preg_match("/[\d.]{7,15}/", $realip, $onlineip); 这里的正则表达式有点不明白,
为什么数字或点要重复七到十五次?
这个是用来匹配ipv6的。
preg_match("/[\d\.]{7,15}/", $realip, $onlineip);
单纯从代码上来解释这个正则,就是指:
匹配 数字或点 7-15次
从逻辑上不是很理解为什么要这么判断
http://www.baike.com/wiki/TCP%2FIP&prd=button_citiao2_search
preg_match("/[\d\.]{7,15}/", $realip, $onlineip);
我仔细想了一下,一个正常的IP可能是这样:
1.1.1.1
(数字+点正好是7位) 192.168.100.101
(数字+点正好是15位)
所以此代码的判断有些可笑,我想他的本意是: 数字加点的长度要在 7-15位之间
但是他没有想到这样的情况也是可以的: 1....1...1.....1
192116821003101