那天寫自己的網站,想到要有關于限制ip的功能,至少要包括能夠在后臺設置要限制的ip,還有,能夠對ip段進行限制,比如 192.168.0.* 一樣的就能夠限制整個段,左思右想,用了好幾個if判斷才解決,把簡單的代碼如下:(程序中使用了phplib中的db類)
<?php
/*********************************************
* 文件:limitip.php
* 用途:ip限制程序
* 版本:v1.0
* 日期:2005-1-7 12:34
* 作者:heiyeluren ([email protected])
* 版權:http://www.unixsky.net
*********************************************/
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校驗結束 ******************/
?>
代碼只是我初步的一個想法,肯定有不足,如果高手有更好建議請不吝賜教!
新聞熱點
疑難解答