娱乐新地带论坛
(
https://bbs.1819.net/index.php)
-
『程序设计』
(
https://bbs.1819.net/forumdisplay.php?f=20)
- -
Php判断ip段代码
(
https://bbs.1819.net/showthread.php?t=34329)
Php判断ip段代码
可以一次禁止一个段
PHP 代码:
/************************************************* 临时配置:自动转空IP列表 *************************************************/ $hack_to_null_ip_list=array( // "218.20.55.53", ); $hack_to_null_ip_domain=array( // "61.135.130", ); ?> <? /********************************************************** 判断是否HACK IP,确认则退出 **********************************************************/ //判断单个IP if (in_array($_SERVER['REMOTE_ADDR'],$hack_to_null_ip_list)) { die("您的IP已被列入禁止列表,请与我们联系!"); } //判断IP段 foreach ($hack_to_null_ip_domain as $r) { $ip=explode(".",$r); $rip=explode(".",$_SERVER['REMOTE_ADDR']); $t=false; for ($i=0;$i<count($ip);$i++) { if ($ip[$i]!=$rip[$i]) $t=true; } if (!$t) die("您的IP段已被列入禁止列表,请与我们联系!"); }
|
PHP 代码:
<?php /********************************************* * 文件:limitip.php * 用途:IP限制程序 * 版本:v1.0 * 日期:2005-1-7 12:34 * 作者:heiyeluren (heiyeluren@163.com) * 版权: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校验结束 ******************/ ?>
|
所有时间均为北京时间。现在的时间是 06:38 PM。 |
|
©2003-2024 1819.net All rights reserved.
© 2024