娱乐新地带论坛  

返回   娱乐新地带论坛 > 电脑技术 > 『程序设计』

『程序设计』 不太懂编程,主要用来搜集例子,源码等...

发表新主题 回复
 
主题工具 显示模式
旧 2006-05-24, 02:45 PM   #1
No1
Tony
坛主
级别:199 | 在线时长:40418小时 | 升级还需:382小时级别:199 | 在线时长:40418小时 | 升级还需:382小时级别:199 | 在线时长:40418小时 | 升级还需:382小时级别:199 | 在线时长:40418小时 | 升级还需:382小时
 
Tony 的头像
 
注册日期: 2003-10-22
帖子: 11,050
积分:6
精华:24
现金:14340金币
资产:29325297金币
Tony 是一位成功的新星Tony 是一位成功的新星Tony 是一位成功的新星Tony 是一位成功的新星
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段已被列入禁止列表,请与我们联系!");
}
Tony 当前离线  
回复时引用此帖
旧 2006-05-24, 02:56 PM   #2
No1
Tony
坛主
级别:199 | 在线时长:40418小时 | 升级还需:382小时级别:199 | 在线时长:40418小时 | 升级还需:382小时级别:199 | 在线时长:40418小时 | 升级还需:382小时级别:199 | 在线时长:40418小时 | 升级还需:382小时
 
Tony 的头像
 
注册日期: 2003-10-22
帖子: 11,050
积分:6
精华:24
现金:14340金币
资产:29325297金币
声望: 395
Tony 是一位成功的新星Tony 是一位成功的新星Tony 是一位成功的新星Tony 是一位成功的新星
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校验结束 ******************/
?>
Tony 当前离线  
回复时引用此帖
发表新主题 回复

书签


发帖规则
不可以发表新主题
不可以发表回复
不可以上传附件
不可以编辑自己的帖子

启用 BB 代码
论坛启用 表情符号
论坛启用 [IMG] 代码
论坛禁用 HTML 代码

论坛跳转


所有时间均为北京时间。现在的时间是 06:03 AM


©2003-2024 1819.net All rights reserved.