基于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 相关文章推荐
session在PHP大型web应用中的使用
Jun 25 PHP
理解和运用PHP中的多态性[译]
Aug 02 PHP
国外PHP程序员的13个好习惯小结
Feb 20 PHP
PHP中使用memcache存储session的三种配置方法
Apr 05 PHP
php使用MySQL保存session会话的方法
Jun 26 PHP
PHP获取网站中各文章的第一张图片的代码示例
May 20 PHP
详谈PHP中的密码安全性Password Hashing
Feb 04 PHP
php生成0~1随机小数的方法(必看)
Apr 05 PHP
Laravel中encrypt和decrypt的实现方法
Sep 24 PHP
PHP面向对象五大原则之里氏替换原则(LSP)详解
Apr 08 PHP
PHP实现二维数组中的查找算法小结
Jun 09 PHP
PHP中如何使用Redis接管文件存储Session详解
Nov 28 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
php实现把数组按指定的个数分隔
2014/02/17 PHP
PHP批量检测并去除文件BOM头代码实例
2014/05/08 PHP
php+ajax实现带进度条的上传图片功能【附demo源码下载】
2016/09/14 PHP
Thinkphp开发--集成极光推送
2017/09/15 PHP
jquery垂直公告滚动实现代码
2013/12/08 Javascript
JQuery结合CSS操作打印样式的方法
2013/12/24 Javascript
JavaScript拆分字符串时产生空字符的解决方案
2014/09/26 Javascript
在linux中使用包管理器安装node.js
2015/03/13 Javascript
jquery trigger函数执行两次的解决方法
2016/02/29 Javascript
js记录点击某个按钮的次数-刷新次数为初始状态的实例
2017/02/15 Javascript
Vue.2.0.5过渡效果使用技巧
2017/03/16 Javascript
Bootstrap 设置datetimepicker在屏幕上面弹出设置方法
2017/03/21 Javascript
Vue2递归组件实现树形菜单
2017/04/10 Javascript
jQuery表单验证之密码确认
2017/05/22 jQuery
微信小程序 JS动态修改样式的实现方法
2018/12/16 Javascript
TypeScript开发Node.js程序的方法
2019/04/30 Javascript
使用 Vue-TCB 快速在 Vue 应用中接入云开发的方法
2020/02/10 Javascript
python时间整形转标准格式的示例分享
2014/02/14 Python
python入门基础之用户输入与模块初认识
2016/11/14 Python
使用Python+Splinter自动刷新抢12306火车票
2018/01/03 Python
深入浅析python with语句简介
2018/04/11 Python
windows 10 设定计划任务自动执行 python 脚本的方法
2019/09/11 Python
python中提高pip install速度
2020/02/14 Python
django orm模块中的 is_delete用法
2020/05/20 Python
python调用摄像头的示例代码
2020/09/28 Python
Spartoo英国:欧洲最大的网上鞋店
2016/09/13 全球购物
香港优质食材和美酒专门店:FoodWise
2017/09/01 全球购物
J2ee常用的设计模式?说明工厂模式
2015/05/21 面试题
计算机专业优秀大学生自我总结
2014/01/21 职场文书
陈欧的广告词
2014/03/18 职场文书
泰山导游词
2015/02/02 职场文书
2015年信贷员工作总结
2015/04/28 职场文书
个人收入证明格式
2015/06/24 职场文书
学校学习型党组织建设心得体会
2019/06/21 职场文书
导游词之苏州盘门景区
2019/11/12 职场文书
Spring Boot 启动、停止、重启、状态脚本
2021/06/26 Java/Android