沈厅野史 磁力:如何用php实现IP限制

来源:百度文库 编辑:中科新闻网 时间:2024/04/29 13:22:11
比如说asdf.php这个文件
如果访问者的ip属于202.198.123.* ~202.198.223.* 这个范围的话就可以访问asdf.php这个页面
如果访问者ip不属于这个范围,则无法访问
请各位高手多多指点,给出详细代码
最好不要涉及数据库,只是简单的在页面内输入代码的那种
非常急~
谢谢

<?php

error_reporting(7);
session_start();

// 发送字符头信息
if ($headercharset)
header("Content-Type:text/html; charset=gb2312");

// 加载公共文件
require_once("config.php");
require_once("global.php");
require_once("db_mysql.php");

/***************** 进行客户端能否访问本网站校验 ************/

// 获取客户端IP
if(getenv('HTTP_CLIENT_IP')) {
$client_ip = getenv('HTTP_CLIENT_IP');
} elseif(getenv('HTTP_X_FORWARDED_FOR')) {
$client_ip = getenv('HTTP_X_FORWARDED_FOR');
} elseif(getenv('REMOTE_ADDR')) {
$client_ip = getenv('REMOTE_ADDR');
} else {
$client_ip = $HTTP_SERVER_VARS['REMOTE_ADDR'];
}

// 分解客户端IP
$cip = explode(".", $client_ip);

// 连接数据库
$db = new DB_Sql();
$err = $db->connect();

/* 限制远程IP访问, PS: 这段代码真晕,呵呵,用了8个if, -_-# */
// 从数据库中提取存储的要限制的IP地址
$query_str = "SELECT limit_ip FROM us_limitip";
$db->query($query_str);
// 把结果循环提取,一个个进行校验
while ($db->next_record())
{
$limit_ip = $db->f("limit_ip");
$lip = explode(".", $limit_ip);
// 如果限制IP的第一个是*或者是0的话就跳到错误页
if (($lip[0]=='*') || ($lip[0]=='0'))
header("Location:../error.php?errid=300");
// 如果刚好客户端IP等于我们限制IP就跳到错误页
if ($client_ip==$limit_ip)
header("Location:../error.php?errid=300");
// 如果第一组IP一致进行第二组IP的匹配
if ($cip[0] == $lip[0])
{
// 如果第二组限制IP是*就跳到错误页
if ($lip[1]=='*')
header("Location:../error.php?errid=300");
// 第二组IP匹配就进行第三组IP匹配
if ($cip[1]==$lip[1])
{
// 如果第三组限制字符是*就跳到错误页
if ($lip[2]=='*')
header("Location:../error.php?errid=300");
// 如果第三组IP匹配就跳到第三组校验
if ($cip[2]==$lip[2])
{
// 如果第四组限制IP是*或0就跳到错误页
if (($lip[3]=='*') || ($lip[3]=='0'))
header("Location:../error.php?errid=300");
}
}
}
}
// 释放数据库查询结果
$db->free();

/****************** IP校验结束 ******************/

?>

//获取远程ip地址
$ip=getenv("REMOTE_ADDR");
//将ip地址分解为4段并放到数组中
$ip_arr=explode(".",$ip);
//前两段ip地址组合成一个字符串
$ip_first=$ip_arr[0].$ip_arr[1];
//第三段ip地址赋给另一个变量
$ip_last=$ip_arr[2];
//判断ip地址是否放行
$ip_first!='202198'?exit('您没有访问许可'):$ip_last<123 || $ip_last>223?exit('您没有访问许可'):1;

代码完毕,这个应该是最简洁的一个程序

楼上兄弟写得不错.不过最好把判断写成一个函数.直接调用就行拉.
<?php
checkIp();
function checkIp()
{
//得到ip
if(getenv('HTTP_CLIENT_IP')) {
$client_ip = getenv('HTTP_CLIENT_IP');
} elseif(getenv('HTTP_X_FORWARDED_FOR')) {
$client_ip = getenv('HTTP_X_FORWARDED_FOR');
} elseif(getenv('REMOTE_ADDR')) {
$client_ip = getenv('REMOTE_ADDR');
} else {
$client_ip = $HTTP_SERVER_VARS['REMOTE_ADDR'];
}

// 分解客户端IP
$cip = explode(".", $client_ip);
//判断
if ($cip[0]=='202' && $cip[1]=='198'&($cip['2']<='223'&$cip['2']>=123)) {
header("Location:asdf.php");//正确拉
}else {
header("Location:error.php");
}
}

?>

应该是$_SERVER['REMOTE_ADDR']