<?php/********************************************** 文件:limitip.php* 用途:IP限制程序*********************************************/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");/***************** 进行客户端能否访问本网站校验 ************/// 获取客户端IPif(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校验结束 ******************/?>