基于PHP开发中的安全防范知识详解


Posted in PHP onJune 06, 2013

PHP代码安全和XSS,SQL注入等对于各类网站的安全非常中用,尤其是UGC(User Generated Content)网站,论坛和电子商务网站,常常是XSS和SQL注入的重灾区。这里简单介绍一些基本编程要点, 相对系统安全来说,php安全防范更多要求编程人员对用户输入的各种参数能更细心.

php编译过程中的安全

建议安装Suhosin补丁,必装安全补丁
php.ini安全设置

register_global = off
magic_quotes_gpc = off
display_error = off
log_error = on
# allow_url_fopen = off
expose_php = off
open_basedir =
safe_mode = on
disable_function = exec,system,passthru,shell_exec,escapeshellarg,escapeshellcmd,proc_close,proc_open,dl,popen,show_source,get_cfg_var
safe_mode_include_dir =

DB SQL预处理
mysql_real_escape_string (很多PHPer仍在依靠addslashes防止SQL注入,但是这种方式对中文编码仍然是有问题的。addslashes的问题在于黑客可以用 0xbf27来代替单引号,GBK编码中0xbf27不是一个合法字符,因此addslashes只是将0xbf5c27,成为一个有效的多字节字符,其 中的0xbf5c仍会被看作是单引号,具体见这篇文章)。用mysql_real_escape_string函数也需要指定正确的字符集,否则依然可能 有问题。

prepare + execute(PDO)
ZendFramework可以用DB类的quote或者quoteInto, 这两个方法是根据各种数据库实施不用方法的,不会像mysql_real_escape_string只能用于mysql

用户输入的处理
无需保留HTML标签的可以用以下方法
strip_tags, 删除string中所有html标签
htmlspecialchars,只对”<”,”>”,”;”,”'”字符进行转义
htmlentities,对所有html进行转义
必须保留HTML标签情况下可以考虑以下工具:

HTML Purifier: HTML Purifier is a standards-compliant HTML filter library written in PHP.
PHP HTML Sanitizer: Remove unsafe tags and attributes from HTML code
htmLawed: PHP code to purify & filter HTML

上传文件
用is_uploaded_file和move_uploaded_file函数,使用HTTP_POST_FILES[]数组。并通过去掉上传目录的PHP解释功能来防止用户上传php脚本。
ZF框架下可以考虑使用File_upload模块
Session,Cookie和Form的安全处理
不要依赖Cookie进行核心验证,重要信息需要加密, Form Post之前对传输数据进行哈希, 例如你发出去的form元素如下:

<input type="hidden" name="H[name]" value="<?php echo $Oname?>"/> <input type="hidden" name="H[age]" value="<?php echo $Oage?>"/> <?php $sign = md5('name'.$Oname.'age'.$Oage.$secret); ?> <input type="hidden" name="hash" value="<?php echo $sign?>"" />
POST回来之后对参数进行验证
$str = "";
foreach($_POST['H'] as $key=>$value) {
$str .= $key.$value;
}
if($_POST['hash'] != md5($str.$secret)) {
echo "Hidden form data modified"; exit;
}

PHP安全检测工具(XSS和SQL Insertion)
Wapiti - Web application security auditor(Wapiti - 小巧的站点漏洞检测工具) (SQL injection/XSS攻击检查工具)

安?/使用方法:
apt-get install libtidy-0.99-0 python-ctypes python-utidylib
python wapiti.py http://Your Website URL/ -m GET_XSS
Pixy: XSS and SQLI Scanner for PHP( Pixy - PHP 源码缺陷分析工具)
安?: apt-get install default-jdk

PHP 相关文章推荐
第八节 访问方式 [8]
Oct 09 PHP
PHP文件读写操作之文件读取方法详解
Jan 13 PHP
php学习笔记之面向对象编程
Dec 29 PHP
PHP echo,print,printf,sprintf函数之间的区别与用法详解
Nov 27 PHP
php基于str_pad实现卡号不足位数自动补0的方法
Nov 12 PHP
PHP中使用xmlreader读取xml数据示例
Dec 29 PHP
php动态生成缩略图并输出显示的方法
Apr 20 PHP
详解PHP中的mb_detect_encoding函数使用方法
Aug 18 PHP
PHP使用PHPexcel导入导出数据的方法
Nov 14 PHP
php 输出json及显示json中的中文汉字详解及实例
Nov 09 PHP
php监测数据是否成功插入到Mysql数据库的方法
Nov 25 PHP
thinkphp Apache配置重启Apache1 restart 出错解决办法
Feb 15 PHP
探讨PHP JSON中文乱码的解决方法详解
Jun 06 #PHP
一些php项目中比较通用的php自建函数的详解
Jun 06 #PHP
强烈声明: 不要使用(include/require)_once
Jun 06 #PHP
探讨PHP调用时间格式的参数详解
Jun 06 #PHP
探讨多键值cookie(php中cookie存取数组)的详解
Jun 06 #PHP
深入密码加salt原理的分析
Jun 06 #PHP
深入理解PHP几个算法:PHP冒泡、PHP二分法、PHP求素数、PHP乘法表
Jun 06 #PHP
You might like
综合图片计数器
2006/10/09 PHP
php的array数组和使用实例简明教程(容易理解)
2014/03/20 PHP
php单一接口的实现方法
2015/06/20 PHP
Yii框架中用response保存cookie,用request读取cookie的原理解析
2019/09/04 PHP
修改好的jquery滚动字幕效果实现代码
2011/06/22 Javascript
jquery.blockUI.js上传滚动等待效果实现思路及代码
2013/03/18 Javascript
js计算字符串长度包含的中文是utf8格式
2013/10/15 Javascript
jQuery实现大转盘抽奖活动仿QQ音乐代码分享
2015/08/21 Javascript
jquery实现适用于门户站的导航下拉菜单效果代码
2015/08/24 Javascript
JavaScript脚本判断蜘蛛来源的方法
2015/09/22 Javascript
Bootstrap按钮下拉菜单组件详解
2016/05/10 Javascript
javascript中数组和字符串的方法对比
2016/07/20 Javascript
AngularJS基础 ng-non-bindable 指令详细介绍
2016/08/02 Javascript
Vue精简版风格概述
2018/01/30 Javascript
移动端H5页面返回并刷新页面(BFcache)的方法
2018/11/06 Javascript
jQuery移动端跑马灯抽奖特效升级版(抽奖概率固定)实现方法
2019/01/18 jQuery
微信小程序视图控件与bindtap之间的问题的解决
2019/04/08 Javascript
vue2 拖动排序 vuedraggable组件的实现
2019/08/08 Javascript
微信小程序实现图片压缩
2019/12/03 Javascript
解决Nuxt使用axios跨域问题
2020/07/06 Javascript
python使用BeautifulSoup分页网页中超链接的方法
2015/04/04 Python
详解Python验证码识别
2016/01/25 Python
python将unicode转为str的方法
2017/06/21 Python
Python实现加载及解析properties配置文件的方法
2018/03/29 Python
Python实现程序判断季节的代码示例
2019/01/28 Python
python实现登录与注册系统
2020/11/30 Python
Expedia挪威官网:酒店、机票和租车
2018/03/03 全球购物
Linux Interview Questions For software testers
2012/06/02 面试题
中国央视网签名寄语
2014/01/18 职场文书
护校行动方案
2014/05/31 职场文书
科级干部群众路线教育实践活动个人对照检查材料
2014/09/19 职场文书
单位车辆管理制度
2015/08/05 职场文书
银行工作心得体会范文
2016/01/23 职场文书
2016年学校爱国卫生月活动总结
2016/04/06 职场文书
详解Django的MVT设计模式
2021/04/29 Python
MySQL之MyISAM存储引擎的非聚簇索引详解
2022/03/03 MySQL