怎样查明sql注入漏洞
admin
2023-05-29 21:42:39
0

今天小编给大家分享的是怎样查明sql注入漏洞的方法介绍,相信大部分人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,话不多说,一起往下看吧。

个人整理:

1.注入字符串数据

    步骤:

        a.提交一个单引号作为目标查询的数据,观察是否会造成错误,或结果是否与原来结果不同。

        b.如果发现错误或其他异常行为,同时提交两个单引号,看会出现什么情况。数据库使用两个单引号作为转义序列,表示一个原因单引号,因此这个序列解释成引用字符串中的数据,而不是结束字符串的终止符。如果这个输入导致错误或异常行为小时,则应用程序可能易于收到sql注入***

        c.为进一步核实漏洞,可以使用sql连接符建立一个等同于“良性”输入的字符串,如果应用程序以与处理对应“良性”输入相同的方式处理专门设计的输入,那么可能易受到***。

            每种数据库连接方式各不相同,如:

                oracle: '||'FOO

                ms-sql:  '+'FOO

                mysql: ' 'FOO 引号之间存在空格


2.注入数字数据:

    如果sql查询合并用户提交的数字数据,应用程序仍然会将它包含在单引号之中,作为字符串数据进行处理,可以按照上面字符串的测试步骤处理。有时候会直接将数字数据传送到数据库中,并不放在单引号中,使用上面方法无法检测到漏洞,可以按照下面测试步骤。

    步骤:

        a.尝试输入一个结果等于原始数字值的简单数学表达式。如,如果原始值是2,可以尝试提交1+1或3-1,如果有相同相应,则表明易受到***。

        b.如果证实被修改的数据会对应用程序造成明显影响,则前面描述的测试方式最为可靠。但是,如果能够在数字化参数中插入任意输入,但程序行为没有发生改变,前面的检查方法就无法发现漏洞。

        c.如果第一个测试方法取得成功,可以利用更加复杂、使用特殊sql关键字和语法的表达式进一步获得与漏洞有关 的证据。ASCII命令就是一个典型的实例,它返回被提交字符的数字化ASCII代码,。例如,A的ASCII值是65,在sql中,以下表达式等于2:

            67-ASCII('A')

        d.如果单引号被过滤掉,那么前面的测试方法就没有用。但是,这时可以利用这样一个事实:即在必要时,数据库会隐含的将数字数据转化成字符串数据。例如,因为字符 1 的ASCII值为49,在sql语句中,以下表达式等于2:

             51-ASCII(1)

    

    特别注意:

      在查探应用程序是否 存在sql注入类缺陷时,我们常常会犯一个错误,即忘记某些字符在http请求中具有特殊含义。如果希望在***有效载荷中插入这些字符,必须谨慎的对他们进行url编码,确保应用程序按照预料的方式解释他们,特别是以下字符:

       - &和=用于连接名/值对,建立查询字符串和post数据块。应当分别使用%26和%3d对他们进行编码。

       - 查询字符串中不允许使用空格,如果在其中提交空格,整个字符串会立即终止。必须使用 + 或 %20 对其编码。

       - 由于 + 用于编码空格,如果想在字符串中使用 + ,必须使用 %2b 对其编码。因此,前面的数字化实例中,1+1应以 1%2b1 的形式提交。

       - 分号用于分隔cookie字段,必须使用 %3b对其编码。

    无论是通过哦拦截代码服务器直接从浏览器中编辑参数值,或是使用其他方法进行编辑,都必须使用这些编码方法。如果没有对相关字符进行编码,那么整个请求可能会无效,或提交预期之外的数据。


3.注入查询结构:

    如果用户提交的数据被插入sql查询结构,而不是查询中的数据项,这时实施sql注入***只需要直接应用有效的sql语法,而不需要进行任何“转义”。

    sql查询结构中最常用的注入点是 order by子句。   

    步骤:

        a.记下任何可能控制应用程序返回的结果的顺序或其中的字段类型的参数。

        b.提供一系列在参数值中提交数字值的请求,从数字 1 开始,然后逐个请求递增。

            - 如果更改输入中的数字会影响结果的顺序,则说明输入可能被插入到order by子句中。

            - 如果提交输入 1 生成一组结果,其中一个列每一行都包含一个 1 ,则说明输入要可能被插入到查询返回的列的名称中,如:

                SELECT 1,title,year from books where publisher='wilery'

        注解:

        在order by子句中实施sql注入与其他注入情形有很大区别,此时,数据中不会接受查询中的union、where、or、and关键字。通常实施注入***需要***者指定一个嵌套查询来替代参数,如用(SELECT 1 WHREE<> or  1/0=0)替代列名称。

看完上诉内容,你们对查明sql注入漏洞大概了解了吗?如果想了解更多相关文章内容,欢迎关注行业资讯频道,感谢各位的阅读!

相关内容

热门资讯

ASML首席执行官Fouque... IT之家 5 月 21 日消息,ASML(阿斯麦)首席执行官 Christophe Fouquet(...
特斯拉监督版FSD官宣入华!智... 特斯拉官方5月21日通过社交媒体公布了监督版全自动驾驶系统(FSD)的最新全球化布局,其中明确提及该...
美国悍然起诉卡斯特罗,航母逼近... 华盛顿以“法律”的名义对古巴使出重手。美国司法部周三指控古巴革命领袖劳尔·卡斯特罗犯有“谋杀罪”,指...
广州举办高校专场海洋科技产业供... 2026年5月15日,广州市规划和自然资源局(广州市海洋局)在城市规划展览中心组织召开2026年第二...
AI如何赋能制造?重庆这场活动... 5月21日下午,2026重庆市“AI+制造”供需对接专场活动在重庆国际博览中心举行。作为第八届中国西...
原创 2... 原汁原味的手机价格战,在618终于回来了,今年上半年阿维推荐手机的频率不高,不是因为我懒,纯粹是因为...
港商云南行|范思达 :AI赋能... AI赋能产业升级 开拓发展新赛道 ——访云南览易网络科技有限责任公司副总经理范思达 5月12日,作为...
国际茶日上线4款特调茶,霸王茶... 来源:新浪科技 5月21日,霸王茶姬上线4款“走走系列”世界茶特调新品。同时,品牌还宣布geelat...
台推红包政策抢救少子化危机,民... 据凤凰卫视报道,台湾少子化问题严重,民进党当局宣布,将规划针对0到18岁的孩童,每人每月发放5000...
从经贸合作到点名日本,中俄42... 【文/观察者网 王慧】5月19日至20日,俄罗斯总统普京对华进行国事访问,这是普京总统第25次到访中...