php防注入及开发安全详细解析
2015-01-24信息快讯网
以下是对php防注入及开发安全进行了详细的分析介绍,需要的朋友可以过来参考下
1、PHP注入的基本原理
程序员的水平及经验也参差不齐,相当大一部分程序员在编写代码的时候,没有对 用户输入数据的合法性进行判断,使应用程序存在安全隐患。用户可以提交一段数据 库查询代码,根据程序返回的结果,获得某些他想得知的数据,这就是所谓的 SQL Injection,即SQL注入。 受影响的系统:对输入的参数不进行检查和过滤的系统.
SQL注入过程
正常来讲,我们通过地址接收一些必要的参数如:
页面中我们会使用 2 写入到SQL语句中
正常情况:Select * From Table where id=2
PHP100.php?id=2
如果我们对SQL语句熟悉,就知道2 我们可以替换成我们需要的SQL语句
如:and exists (select id from admin)
2、防止注入的几种办法
其实原来就是我们需要过滤一些我们常见的关键字和符合如:
Select,insert,update,delete,and,*,等等
例子:
function inject_check($sql_str) { return preg_match('/select|insert|update|delete|/'|///*|/*|/././/|/.//|union|into|load_file|outfile/i', $sql_str); // 进行过滤 }
或者是通过系统函数间的过滤特殊符号
Addslashes(需要被过滤的内容)
3、PHP其他地方安全设置
register_globals = Off 设置为关闭状态
SQL语句书写时尽量不要省略小引号和单引号
Select * From Table Where id=2 (不规范) Select * From ・Table・ Where ・id・='2' (规范)
提高数据库命名技巧,对于一些重要的字段可根据程序特点命名
对于常用方法加以封装,避免直接暴露SQL语句
正确的使用 $_POST $_GET $_SESSION 等接受参数,并加以过滤
php分页示例分享
php+js iframe实现上传头像界面无跳转
php数组查找函数in_array()、array_search()、array_key_exists()使用实例
PHP的MVC模式实现原理分析(一相简单的MVC框架范例)
php中使用getimagesize获取图片、flash等文件的尺寸信息实例
Windows下的PHP安装文件线程安全和非线程安全的区别
PHP开发中常见的安全问题详解和解决方法(如Sql注入、CSRF、Xss、CC等)
Session的工作机制详解和安全性问题(PHP实例讲解)
PHP四大安全策略
php中sql注入漏洞示例 sql注入漏洞修复
php防止sql注入示例分析和几种常见攻击正则表达式
输入值/表单提交参数过滤有效防止sql注入的方法
php防止sql注入代码实例
解析数组非数字键名引号的必要性
分割GBK中文遭遇乱码的解决方法
PHP中怎样保持SESSION不过期 原理及方案介绍
php中用socket模拟http中post或者get提交数据的示例代码
浅析php变量作用域的一些问题
解析php开发中的中文编码问题
php中jpgraph类库的使用介绍
PHP 线程安全与非线程安全版本的区别深入解析
PHP 安全检测代码片段(分享)
浅析php过滤html字符串,防止SQL注入的方法
浅谈web上存漏洞及原理分析、防范方法(安全文件上存方法)
解析web文件操作常见安全漏洞(目录、文件名检测漏洞)
解析php安全性问题中的:Null 字符问题
sql注入与转义的php函数代码
探讨php中防止SQL注入最好的方法是什么
php防注入,表单提交值转义的实现详解
Php中用PDO查询Mysql来避免SQL注入风险的方法