什么是sql注入漏洞


本文摘自PHP中文网,作者清浅,侵删。

SQL注入漏洞指的是将恶意输入的SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令

SQL注入漏洞

顾名思义,SQL注入漏洞就是允许攻击者将恶意输入注入SQL语句。要完全理解该问题,我们首先必须了解服务器端脚本语言是如何处理SQL查询。

例如,假设Web应用程序中的功能使用以下SQL语句生成一个字符串:

1

$statement = "SELECT * FROM users WHERE username = 'bob' AND password = 'mysecretpw'";

此SQL语句将传递给一个函数,该函数将字符串发送到已连接的数据库,在该数据库中对其进行解析,执行并返回结果。

您可能已经注意到该语句包含一些新的特殊字符:

  • * :是SQL数据库返回所选数据库行的所有列的指令

  • = :是SQL数据库仅返回与搜索到的字符串匹配的值的指令

  • ' :用于告诉SQL数据库搜索字符串的开始或结束位置

现在考虑以下示例,网站用户可以更改“$ user”和“$ password”的值,例如在登录表单中:

1

$statement = "SELECT * FROM users WHERE username = '$user' AND password= '$password'";

如果应用程序未对输入进行清理,攻击者可以在语句中轻松插入任何特殊的SQL语法:

1

$statement = "SELECT * FROM users WHERE username = 'admin'; -- ' AND password= 'anything'";= 'anything'";

  • admin'; - :是攻击者的输入,其中包含两个新的特殊字符:

  • ; :用于指示SQL解析器当前语句已结束(在大多数情况下不需要)

  • - :指示SQL解析器该行的其余部分

此SQL注入有效地删除了密码验证,并返回现有用户的数据集,在这种情况下为“admin”攻击者现在可以使用管理员帐户登录,而无需指定密码。

以上就是什么是sql注入漏洞的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

mysql怎样防止SQL注入问题

了解SQL注入及如何解决

mysql如何防止SQL注入

SQL注入一般可通过网页表单直接输入么

确定SQL注入死透了么?

快速了解SQL注入基本原理

什么是SQL注入?带你从零开始认识SQL注入

什么是SQL注入漏洞

如何防止SQL注入攻击?

常见SQL注入的方法

更多相关阅读请进入《SQL注入》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...