php如何防范sql注入攻击 sql注入原理解析
本文导语: SQL 注入是php教程中最常提及的漏洞之一。 开发者要同时犯两个错误才会引发一个sql注入漏洞,一个是没有对输入的数据进行过滤(过滤输入),还有一个是没有对发送到数据库的数据进行转义(转义输出)。 这两个重要的步...
SQL 注入是php教程中最常提及的漏洞之一。
开发者要同时犯两个错误才会引发一个sql注入漏洞,一个是没有对输入的数据进行过滤(过滤输入),还有一个是没有对发送到数据库的数据进行转义(转义输出)。
这两个重要的步骤缺一不可,需要同时加以特别关注以减少程序错误。
对于攻击者来说,进行sql注入攻击需要思考和试验,对数据库方案进行有根有据的推理非常有必要(当然假设攻击者看不到你的源程序和数据库方案),考虑以下简单的登录表单:
Username:
Password:
作为一个攻击者,他会从推测验证用户名和密码的查询sql语句开始。
通过查看源文件,他就能开始猜测你的习惯。
比如命名习惯。
通常会假设你表单中的字段名为与数据表中的字段名相同。
当然,确保它们不同未必是一个可靠的安全措施。
- php防范SQL注入攻击与XSS攻击的方法
- 使用PDO查询Mysql来避免SQL注入风险
- php防止sql注入漏洞过滤函数
- php防止sql注入正则过滤
- php sql注入式攻击
第一次猜测,一般会使用下面例子中的查询:
当然,攻击者未必在第一次就能猜中,他们常常还需要做一些试验。有一个比较好的试验方式是把单引号作为用户名录入,原因是这样可能会暴露一些重要信息。有很多开发人员在Mysql语句执行出错时会调用函数mysql_error()来报告错误。见下面的例子:
虽然该方法在开发中十分有用,但它能向攻击者暴露重要信息。如果攻击者把单引号做为用户名,mypass做为密码,查询语句就会变成: