【干货】如何判断 Sql 注入点

【干货】如何判断 Sql 注入点

注:本文在Jewel591 文章的基础上加以实例说明而成 原文链接

1.判断是否存在 Sql 注入漏洞2.判断 Sql 注入漏洞的类型2.1 数字型判断:2.2 字符型判断:

3.实例说明less-1(字符型注入)数值型方法判断字符型方法判断

less-2(数值型注入)数值型方法判断

less-3(字符型注入)字符型方法判断

通常情况下,可能存在 Sql 注入漏洞的 Url 是类似这种形式 :http://xxx.xxx.xxx/abcd.php?id=XX对 Sql 注入的判断,主要有两个方面:

判断该带参数的 Url 是否存在 Sql 注入?如果存在 Sql 注入,那么属于哪种 Sql 注入?

可能存在 Sql 注入攻击的 ASP/PHP/JSP 动态网页中,一个动态网页中可能只有一个参数,有时可能有多个参数。有时是整型参数,有时是字符串型参数,不能一概而论。总之只要是带有参数的 动态网页且此网页访问了数据库,那么就有可能存在 Sql 注入。如果程序员没有足够的安全意识,没有进行必要的字符过滤,存在SQL注入的可能性就非常大。

1.判断是否存在 Sql 注入漏洞

最为经典的单引号判断法: 在参数后面加上单引号,比如: http://xxx/abc.php?id=1' 如果页面返回错误,则存在 Sql 注入。 原因是无论字符型还是整型都会因为单引号个数不匹配而报错。 (如果未报错,不代表不存在 Sql 注入,因为有可能页面对单引号做了过滤,这时可以使用判断语句进行注入,因为此为入门基础课程,就不做深入讲解了)

2.判断 Sql 注入漏洞的类型

通常 Sql 注入漏洞分为 2 种类型:

数字型字符型

其实所有的类型都是根据数据库本身表的类型所产生的,在我们创建表的时候会发现其后总有个数据类型的限制,而不同的数据库又有不同的数据类型,但是无论怎么分常用的查询数据类型总是以数字与字符来区分的,所以就会产生注入点为何种类型。

2.1 数字型判断:

当输入的参 x 为整型时,通常 abc.php 中 Sql 语句类型大致如下:select * from <表名> where id = x这种类型可以使用经典的 and 1=1 和 and 1=2 来判断:

Url 地址中输入 http://xxx/abc.php?id= x and 1=1 页面依旧运行正常,继续进行下一步。Url 地址中继续输入 http://xxx/abc.php?id= x and 1=2 页面运行错误,则说明此 Sql 注入为数字型注入。

原因如下:

当输入 and 1=1时,后台执行 Sql 语句:select * from <表名> where id = x and 1=1 没有语法错误且逻辑判断为正确,所以返回正常。当输入 and 1=2时,后台执行 Sql 语句:select * from <表名> where id = x and 1=2 没有语法错误但是逻辑判断为假,所以返回错误。

我们再使用假设法:如果这是字符型注入的话,我们输入以上语句之后应该出现如下情况: select * from <表名> where id = 'x and 1=1' select * from <表名> where id = 'x and 1=2' 查询语句将 and 语句全部转换为了字符串,并没有进行 and 的逻辑判断,所以不会出现以上结果,故假设是不成立的。

2.2 字符型判断:

当输入的参 x 为字符型时,通常 abc.php 中 SQL 语句类型大致如下:select * from <表名> where id = 'x'这种类型我们同样可以使用 and ‘1’='1 和 and ‘1’='2来判断:

Url 地址中输入 http://xxx/abc.php?id= x' and '1'='1 页面运行正常,继续进行下一步。Url 地址中继续输入 http://xxx/abc.php?id= x' and '1'='2 页面运行错误,则说明此 Sql 注入为字符型注入。

原因如下:

当输入 and ‘1’='1时,后台执行 Sql 语句:select * from <表名> where id = 'x' and '1'='1'语法正确,逻辑判断正确,所以返回正确。当输入 and ‘1’='2时,后台执行 Sql 语句:select * from <表名> where id = 'x' and '1'='2'语法正确,但逻辑判断错误,所以返回正确。同学们同样可以使用假设法来验证。

3.实例说明

less-1(字符型注入)

拼接方式:id=’$id’ id=1’

数值型方法判断

https://sqli.wmcoder.site/sqli-labs/Less-1/?id=1 and 1=1

https://sqli.wmcoder.site/sqli-labs/Less-1/?id=1 and 1=2

and 1=1 和 and 1=2 均回显正常,并非数字型

字符型方法判断

https://sqli.wmcoder.site/sqli-labs/Less-1/?id=1' and '1'='1

https://sqli.wmcoder.site/sqli-labs/Less-1/?id=1' and '1'='2

and ‘1’='1 回显正常,and ‘1’='2回显异常,说明此 Sql 注入为字符型注入。

less-2(数值型注入)

拼接方式:id=$id id=1

数值型方法判断

https://sqli.wmcoder.site/sqli-labs/Less-2/?id=1 and 1=1

https://sqli.wmcoder.site/sqli-labs/Less-2/?id=1 and 1=2

and 1=1 回显正常 , and 1=2 均回显异常,为数字型注入

less-3(字符型注入)

拼接方式:id=(’$id’) id=1’)

字符型方法判断

https://sqli.wmcoder.site/sqli-labs/Less-3/?id=1' and '1'='1

https://sqli.wmcoder.site/sqli-labs/Less-3/?id=1' and '1'='2

and ‘1’='1 回显正常,and ‘1’='2回显异常,说明此 Sql 注入为字符型注入。

相关推荐

著名演员靳东,在北京的顶级豪宅,10万一平,看看有多气派
为什么我们反对IPO疯狂发行?我们上市企业已经超2万家了,你可能不信,看看事实。首先,中国上市公司数量太多,全球最多,A...
揭秘过一个新年需要花费多少钱?
365足球体育亚洲版

揭秘过一个新年需要花费多少钱?

📅 08-01 👁️ 6859
怎么看女生是不是处
365足球体育亚洲版

怎么看女生是不是处

📅 08-17 👁️ 9708
蓝色可乐是什么牌子?蓝色可乐是百事可乐旗下的吗
域名过期以后多长时间才能被重新注册
365bet网络娱乐

域名过期以后多长时间才能被重新注册

📅 07-12 👁️ 6839
为什么我们反对IPO疯狂发行?我们上市企业已经超2万家了,你可能不信,看看事实。首先,中国上市公司数量太多,全球最多,A...
淘气租怎么样靠谱吗?
365bet网络娱乐

淘气租怎么样靠谱吗?

📅 07-25 👁️ 4566
今晚,德国对阵西班牙!
365bet线上足球

今晚,德国对阵西班牙!

📅 09-14 👁️ 4482