php 应用程序安全防范技术研究


Posted in PHP onSeptember 25, 2009

PHP安全防范程序模型

/* PHP防注入跨站V1.0 

在您的页面顶部添加: require(“menzhi_injection.php”); 

即可实现通用防止SQL注入,以及XSS跨站漏洞。 

##################缺陷以及改进################## 

程序还有很多缺陷,希望大家能帮助改进 

##################参考以及鸣谢################## 

Neeao'ASP SQL通用防注入程序 V3.0 

部分代码参考自Discuz! 

*/ 

error_reporting(0); 

define('MAGIC_QUOTES_GPC', get_magic_quotes_gpc()); 

$menzhi_injection="'|;|and|(|)|exec|insert|select|delete|update|count|*|%|chr|mid|master|truncate|or|char|declare"; 

$menzhi_injection = explode("|",$menzhi_injection); 

foreach(array('_GET', '_POST', '_COOKIE','_REQUEST') as $_request) { 

foreach($$_request as $_key => $_value) { 

//$_value = strtolower($_value); 

$_key{0} != '_' && $$_key = daddslashes($_value); 

foreach($menzhi_injection as $kill_key => $kill_value) { 

if(substr_count($_value,$kill_value)>0) { 

echo ""; 

unset($_value); 

exit(); 

} 

} 

//echo " 

".$_value; 

} 

} 

function daddslashes($string) { 

if(!MAGIC_QUOTES_GPC) { 

if(is_array($string)) { 

foreach($string as $key => $val) { 

$string[$key] = daddslashes($val); 

} 

} else { 

$string = addslashes($string); 

} 

} 

$string = preg_replace('/&((#(\d{3,5}|x[a-fA-F0-9]{4}));)/', '&\\1',str_replace(array('&', '"', '<', '>'), array('&', '"', '<', '>'), $string)); 

return $string; 

} 

?>

使用说明

在您的页面顶部添加:“require(“menzhi_injection.php”);” , 即可实现通用防止SQL注入,以及XSS跨站漏洞。调用本程序,我们使用require() 而不使用include() ,因为require()调用文件如果出错,将终止程序运行,include()并不理会。并且require()调用文件时,程序一运行,会先调用外本文件。而inculde()则是运行到该行时才开始执行。基于函数特性,我们选择require()。 您还可以根据实际需要自行增加或者删除$menzhi_injection变量中的过滤字符,来达到更好的防御效果。 再者您可以自行修改代码,或许会有有意外收获。普通注射都可以防御,以下测试仅供调侃,下面是对一句话木马的测试效果:


php 应用程序安全防范技术研究

嘿嘿,动心了就在您的页面顶部调用吧。记住是“require(“menzhi_injection.php”);”哦。这只是提起大家兴趣的噱头,请自行测试吧。

缺陷以及待改进

由于此程序只是外部调用,只是处理了外部提交的变量,并没有对您的应用程序作系统分析,所以存在很多局限性,请谨慎使用。 对于使用GBK编码的程序,还存在双字节编码漏洞风险,本程序虽然可以处理该漏洞。但遏制这些漏洞,还是需要从根源做起。需要处理数据库连接文件,我们可以添加 character_set_client=binary 。Discuz!7.0的数据库连接类db_mysql.class.php写的就非常不错,大家可以参考借鉴。当然这些并不是这个小程序所能涉及到的范畴。

而且此程序并没有过滤 $_SERVER $_ENV $_FILES系统变量。比如对于$_SERVER['HTTP_X_FORWARDED_FOR']系统获取IP时,黑客可以通过劫持修改HTTP原始请求包来更改其值,本程序是可以处理这些漏洞。但是作为程序员我们需要的是从根源就对外部变量处理,防患于未然,未雨绸缪吧。

程序很潦草,欢迎大家测试使用,有什么意见建议直接联系我吧。

结束语

最后祝大家学习有成,工作顺利,向所有辛勤工作的PHPers致敬。

PHP 相关文章推荐
PHP4 与 MySQL 数据库操作函数详解
Oct 09 PHP
消息持续发送的完整例子
Oct 09 PHP
php中的数组操作函数整理
Aug 18 PHP
php仿discuz分页效果代码
Oct 02 PHP
PHP中怎样防止SQL注入分析
Oct 23 PHP
PHP使用适合阅读的格式显示文件大小的方法
Mar 05 PHP
PHP利用二叉堆实现TopK-算法的方法详解
Apr 24 PHP
PHP让数组中有相同值的组成新的数组实例
Dec 31 PHP
PHP基于DateTime类解决Unix时间戳与日期互转问题【针对1970年前及2038年后时间戳】
Jun 13 PHP
thinkPHP框架实现的简单计算器示例
Dec 07 PHP
PHP使用观察者模式处理异常信息的方法详解
Sep 24 PHP
laravel框架路由分组,中间件,命名空间,子域名,路由前缀实例分析
Feb 18 PHP
从Web查询数据库之PHP与MySQL篇
Sep 25 #PHP
php 服务器调试 Zend Debugger 的安装教程
Sep 25 #PHP
php 代码优化的42条建议 推荐
Sep 25 #PHP
PHP下通过系统信号量加锁方式获取递增序列ID
Sep 25 #PHP
PHP 日常开发小技巧
Sep 23 #PHP
php程序之die调试法 快速解决错误
Sep 17 #PHP
火车采集器 免费版使出收费版本功能实现原理
Sep 17 #PHP
You might like
PHP获取MSN好友列表类的实现代码
2013/06/23 PHP
Smarty foreach控制循环次数的实现详解
2013/07/03 PHP
PHP Curl多线程原理实例详解
2013/11/06 PHP
PHP生成自定义长度随机字符串的函数分享
2014/05/04 PHP
jqPlot Option配置对象详解
2009/07/25 Javascript
简略的前端架构心得&amp;&amp;基于editor为例子的编码小技巧
2010/11/25 Javascript
jQuery创建DOM元素实例解析
2015/01/19 Javascript
JavaScript检测实例属性, 原型属性
2015/02/04 Javascript
JQuery查找DOM节点的方法
2015/06/11 Javascript
JavaScript中数组去除重复的三种方法
2016/04/22 Javascript
js实现背景图自适应窗口大小
2017/01/10 Javascript
jquery基于layui实现二级联动下拉选择(省份城市选择)
2017/06/20 jQuery
webpack v4 从dev到prd的方法
2018/04/02 Javascript
mpvue构建小程序的方法(步骤+地址)
2018/05/22 Javascript
在vue项目中引用Iview的方法
2018/09/14 Javascript
使用 Angular RouteReuseStrategy 缓存(路由)组件的实例代码
2019/11/01 Javascript
js实现简单图片拖拽效果
2021/02/22 Javascript
python实现用户登陆邮件通知的方法
2015/07/09 Python
python中pytest收集用例规则与运行指定用例详解
2019/06/27 Python
Apache,wsgi,django 程序部署配置方法详解
2019/07/01 Python
Python进程间通信 multiProcessing Queue队列实现详解
2019/09/23 Python
利用python实现.dcm格式图像转为.jpg格式
2020/01/13 Python
python求最大公约数和最小公倍数的简单方法
2020/02/13 Python
python + selenium 刷B站播放量的实例代码
2020/06/12 Python
HTML5不支持标签和新增标签详解
2016/06/27 HTML / CSS
新加坡最早生产电动滑板车的制造商之一:FunsToTheFore
2020/09/08 全球购物
介绍一下Make? 为什么使用make
2013/12/08 面试题
策划创业计划书
2014/02/06 职场文书
新闻学专业职业生涯规划范文:我的人生我做主
2014/09/12 职场文书
2014年绿化工作总结
2014/12/09 职场文书
关于颐和园的导游词
2015/01/30 职场文书
护士个人总结范文
2015/02/13 职场文书
微信搭讪开场白
2015/05/28 职场文书
服装店员工管理制度
2015/08/07 职场文书
Nginx Rewrite使用场景及配置方法解析
2021/04/01 Servers
Nginx开源可视化配置工具NginxConfig使用教程
2022/06/21 Servers