<?php /** EasySite FireWall 防火墙模块 13:25 2012/7/23 */ define('FW_ADMIN_KEY', '21232f297a57a5a743894a0e4a801fc3'); // 超级管理员密钥 define('FW_IP_RULE_FILE', APP_PATH.'Runtime/Conf/Config.Iprule.php'); $FW_DEFEND_IP_ON = false; // 开启IP规则过滤 $FW_DEFEND_IP_TP = 1; // 开设置IP过滤模式 0-IP黑名单过滤 1-IP白名单过滤 $FW_DEFEND_CC_ON = false; // 开启防恶意刷新 $FW_DEFEND_CC_TL = 5; // 每五次请求最小间隔时间/S if(isset($_GET['fwkey']) || isset($_COOKIE['es_admin_fwkey'])){ $fwkey = isset($_GET['fwkey']) ? trim($_GET['fwkey']) : (isset($_COOKIE['es_admin_fwkey']) ? $_COOKIE['es_admin_fwkey'] : ''); if($fwkey === FW_ADMIN_KEY) $FW_DEFEND_IP_ON = $FW_DEFEND_CC_ON = false; setcookie('es_admin_fwkey', $fwkey, time()+3600*24, SITE_PATH); } if(true === $FW_DEFEND_IP_ON){ $client_ip = get_client_ip2(); $MYFW_LIST = (include FW_IP_RULE_FILE); if(1 === $FW_DEFEND_IP_TP){ $allowed = false; $MYFW_LIST = parse_ip_list($MYFW_LIST['whitelist']); foreach($MYFW_LIST as $ip){ if(preg_match($ip, $client_ip)){ $allowed = true; break; } } if(!$allowed){ header('HTTP/1.1 403 Forbidden'); exit('HTTP/1.1 403 ES FireWall Forbidden : Not allowed IP'); } }else{ $MYFW_LIST = parse_ip_list($MYFW_LIST['blacklist']); foreach($MYFW_LIST as $ip){ if(preg_match($ip, $client_ip)){ header('HTTP/1.1 403 Forbidden'); exit('HTTP/1.1 403 ES FireWall Forbidden : Not allowed IP'); } } } unset($allowed, $client_ip, $MYFW_LIST); } if(true === $FW_DEFEND_CC_ON){ if(!session_id()) session_start(); $nowtime = $lasttime = $_SERVER['REQUEST_TIME']; if(isset($_SESSION['FireWall'])){ $lasttime = intval($_SESSION['FireWall']['lasttime']); $fwtimes = intval($_SESSION['FireWall']['fwtimes']) + (isset($_SERVER['HTTP_X_REQUESTED_WITH']) ? 0 : 1); $_SESSION['FireWall']['fwtimes'] = $fwtimes; if(($nowtime - $lasttime) < $FW_DEFEND_CC_TL){ if($fwtimes >= 5){ header('HTTP/1.1 403 Forbidden'); $_SESSION['FireWall']['lasttime'] = $nowtime; exit('HTTP/1.1 403 ES FireWall Forbidden : Not allowed CC'); } }else{ $_SESSION['FireWall']['fwtimes'] = 0; $_SESSION['FireWall']['lasttime'] = $nowtime; } }else{ $_SESSION['FireWall']['fwtimes'] = 1; $_SESSION['FireWall']['lasttime'] = $nowtime; } unset($nowtime, $lasttime, $fwtimes); } ?>
2. [PHP]代码
<?php /** * 获取客户端IP * @param void * @return String 客户端IP */ function get_client_ip2(){ 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']; } return $client_ip; } /** * 解析IP规则列表 * @param void * @return Array IP规则列表 */ function parse_ip_list($rules){ $arr = array(); foreach($rules as $rule){ if($rule['start_time'] > $_SERVER['REQUEST_TIME'] || $rule['end_time'] < $_SERVER['REQUEST_TIME']) continue; $ip = str_replace('.', '\.', $rule['ip']); if($start = strstr($ip, '-')){ $start = substr($ip, 0, - strlen(strrchr($ip, '.')) + 1); $pos = explode('-', trim(strrchr($ip, '.'), '.')); for($i=intval($pos[0]),$a=intval($pos[1])+1; $i < $a; $i++ ){ $arr[] = '#^'.$start.$i.'$#i'; } }elseif($start = strstr($ip, '[')){ $_ips = explode('|', substr($start, 1, -1)); $arr[] = '#^'.substr($ip, 0, - strlen($start)).'(('.implode(')|(',$_ips ).'))'.'$#i'; }elseif(strpos($ip, '*')){ $arr[] = '#^'.str_replace('*', '((25[0-5])|(2[0-4]\\d)|(1\\d{2})|(\\d{1,2}))', $ip).'$#i'; }else{ $arr[] = '#^'.$ip.'$#i'; } } return $arr; } ?>
以上就是EasySite FireWall 防火墙模块的内容,更多相关内容请关注PHP中文网(www.php.cn)!
声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章
刺客信条阴影:贝壳谜语解决方案
3 周前ByDDD
Windows 11 KB5054979中的新功能以及如何解决更新问题
2 周前ByDDD
刺客信条阴影 - 如何找到铁匠,解锁武器和装甲定制
1 个月前ByDDD
在哪里可以找到原子中的起重机控制钥匙卡
3 周前ByDDD
<🎜>:死铁路 - 如何完成所有挑战
3 周前ByDDD

热工具

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

Dreamweaver CS6
视觉化网页开发工具