可以用以下函数来获取访客的客户端IP地址:
<?php
function get_client_ip() {
$ip = $_SERVER['REMOTE_ADDR'];
if (isset($_SERVER['HTTP_CLIENT_IP']) && preg_match('/^([0-9]{1,3}\.){3}[0-9]{1,3}$/', $_SERVER['HTTP_CLIENT_IP'])) {
$ip = $_SERVER['HTTP_CLIENT_IP'];
} elseif (isset($_SERVER['HTTP_X_FORWARDED_FOR']) and preg_match_all('#\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}#s', $_SERVER['HTTP_X_FORWARDED_FOR'], $matches)) {
foreach ($matches[0] as $xip) {
if (!preg_match('#^(10|172\.16|192\.168)\.#', $xip)) {
$ip = $xip;
break;
}
}
}
return $ip;
}
再来一个版本的代码,这个版本增加了对使用代理情况下的判断,根据需要选一个用就可以了:
<?php
/**
* 获取客户端IP
*/
function getClientIp() {
$ip = 'unknown';
$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'];
}
// 处理多层代理的情况
if (strpos($ip, ',') !== false) {
// 输出第一个IP
$ip = reset(explode(',', $ip));
}
return str_replace('.', '_', $ip);
}