前段时间一个朋友找到我,需要在他的服务器上实现根据IP地址来限制访问者,服务器环境为WIN+PHPStudy,经过查找资料和测试,成功达到了朋友要求,现在把代码分享给大家,非常简单明了,可用性强。
<?php
header("Content-type: text/html; charset=utf-8");
if(ip_in_network(getIP(),"192.168.0.1","192.168.0.55"))//判断IP段
{
header("Location:http://www.baidu.com");//在IP段内的用户跳转到此链接
}
else
{
header("Location:http://www.csdn.net");//不在IP段内的用户跳转到此链接
}
//获取用户IP
function getIP()
{
if(getenv("HTTP_CLIENT_IP") && strcasecmp(getenv("HTTP_CLIENT_IP"), "unknown"))
$ip = getenv("HTTP_CLIENT_IP");
elseif(getenv("HTTP_X_FORWARDED_FOR") && strcasecmp(getenv("HTTP_X_FORWARDED_FOR"), "unknown"))
$ip = getenv("HTTP_X_FORWARDED_FOR");
elseif (getenv("REMOTE_ADDR") && strcasecmp(getenv("REMOTE_ADDR"), "unknown"))
$ip = getenv("REMOTE_ADDR");
elseif (isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], "unknown"))
$ip = $_SERVER['REMOTE_ADDR'];
else
$ip = "0.0.0.0";
return $ip;
}
//判断IP是否在某段IP内
function ip_in_network($user_ip, $ip_start, $ip_end)
{
$ip=ip2long($user_ip);
$start=ip2long($ip_start); //ip段开始
$end=ip2long($ip_end);//ip段结束
if ($ip>=$start && $ip<=$end)
{
return true;
}
return false;
}
?>