浅谈浅谈SQL注入注入
一、什么是一、什么是SQL注入?注入?
SQL注入是一种注入攻击,可以执行恶意SQL语句。它通过将任意SQL代码插入数据库查询,使攻击者能够完全控制Web应
用程序后面的数据库服务器。攻击者可以使用SQL注入漏洞绕过应用程序安全措施,可以绕过网页或Web应用程序的身份验
证和授权,并检索整个SQL数据库的内容;还可以使用SQL注入来添加,修改和删除数据库中的记录。也就是说web应用程序
对用户输入数据的合法性没有判断或过滤不严,攻击者可以在管理员不知情的情况下实现非法操作,以此来实现欺骗数据库服
务器执行非授权的任意查询,从而进一步得到相应的数据信息。
二、二、SQL注入攻击的类型:注入攻击的类型:
1.带内注入带内注入
这是典型的攻击,攻击者可以通过相同的通信通道发起攻击并获得结果。这是通过两种带内技术完成的:
● 基于错误的SQL注入:从显示的错误消息中获取有关数据库的信息
● 基于联合的SQL注入:依赖于攻击者能够将UNION ALL被盗信息的结果与合法结果连接起来。
这两种技术都依赖于攻击者修改应用程序发送的SQL,以及浏览器中显示的错误和返回的信息。如果应用程序开发人员或数据
库开发人员无法正确地参数化他们在查询中使用的值,那么它就会成功。两者都是试错法,可以检测到错误。
2.盲注入盲注入
也称为推理SQL注入,盲注入攻击不会直接从目标数据库中显示数据;相反,攻击者会仔细检查行为中的间接线索。HTTP响
应中的详细信息,某些用户输入的空白网页以及数据库响应某些用户输入需要多长时间,这些都可以是线索,具体取决于攻击
者的目标。他们还可以指向攻击者尝试的一个SQL攻击途径。
3.带外注入带外注入
这种攻击有点复杂,当攻击者无法在单个直接查询或响应攻击中实现其目标时,攻击者可能会使用此攻击。通常,攻击者会制
作SQL语句,这些语句在呈现给数据库时会触发数据库系统创建与攻击者控制的外部服务器的连接。以这种方式,攻击者可以
收集数据或可能控制数据库的行为。
三、如何防止三、如何防止SQL注入攻击?注入攻击?
1.不要使用动态不要使用动态SQL
避免将用户提供的输入直接放入SQL语句中,最好使用准备好的语句和参数化查询,这样更安全。
2.不要将敏感数据保留在纯文本中不要将敏感数据保留在纯文本中
加密存储在数据库中的私有/机密数据;这样可以提供了另一级保护,以防攻击者成功地排出敏感数据。
3.限制数据库权限和特权限制数据库权限和特权
将数据库用户的功能设置为最低要求;这将限制攻击者在设法获取访问权限时可以执行的操作。
4.避免直接向用户显示数据库错误避免直接向用户显示数据库错误
攻击者可以使用这些错误消息来获取有关数据库的信息。
5.对访问数据库的对访问数据库的Web应用程序使用应用程序使用Web应用程序防火墙(应用程序防火墙(WAF))
这为面向Web的应用程序提供了保护,它可以帮助识别SQL注入尝试;根据设置,它还可以帮助防止SQL注入尝试到达应用
程序(以及数据库)。
6.定期测试与数据库交互的定期测试与数据库交互的Web应用程序应用程序
这样做可以帮助捕获可能允许SQL注入的新错误或回归。
7.将数据库更新为最新的可用修补程序将数据库更新为最新的可用修补程序
这可以防止攻击者利用旧版本中存在的已知弱点/错误。
四、总结:四、总结:
SQL注入是一种流行的攻击方法,但是通过采取适当的预防措施,例如确保数据加密,保护和测试Web应用程序,以及最新
的补丁程序,就可以采取有意义的步骤来保持数据库的安全。
作者:宋文轩-Alex
评论0
最新资源