这篇文章主要介绍“Wireshark分析出攻击者sql注入时查询了哪些数据”,在日常操作中,相信很多人在Wireshark分析出攻击者sql注入时查询了哪些数据问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Wireshark分析出攻击者sql注入时查询了哪些数据”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
0x001 题目
0x002 查看注入语句
将流量包导入Wireshark
看着很乱,输入url
通过浏览器请求使用的协议为http/https
,该流量包中只有http
,所以我们直接过滤出http
协议的数据包。
过滤出http请求的数据包
注入语句如下:
http://localhost:81/?id=1' and ascii(substring((select keyid from flag limit 0,1),1,1))=32#
由此可见攻击者采用布尔盲注进行sql注入。
0x003 观察响应包
这里我们想到注入语句成功和失败所返回的数据包一定是不同的。
观察sql
注入响应包。
注入失败响应内容:
注入成功响应内容:
由此我们可以想到是不是可以先将注入成功响应包过滤出来???那么我们应该以什么规则进行过滤呢,或者说以响应包哪个特征进行过滤呢???
我想到的过滤条件:
过滤出响应内容中有文章内容的所有响应包
根据响应包的长度进行过滤
注入失败的响应包长度:
注入成功的响应包长度:
对于Wireshark的语法不是很熟悉,没有找到怎么以内容过滤的语法,所以我这里以响应包的长度进行过滤。
Wireshark http过滤规则:
http.host==magentonotes.com http.host contains magentonotes.com //过滤经过指定域名的http数据包,这里的host值不一定是请求中的域名 http.response.code==302 //过滤http响应状态码为302的数据包 http.response==1 //过滤所有的http响应包 http.request==1 //过滤所有的http请求,貌似也可以使用http.request http.request.method==POST //wireshark过滤所有请求方式为POST的http请求包,注意POST为大写 http.cookie contains guid //过滤含有指定cookie的http数据包 http.request.uri==”/online/setpoint” //过滤请求的uri,取值是域名后的部分 http.request.full_uri==” http://task.browser.360.cn/online/setpoint” //过滤含域名的整个url则需要使用http.request.full_uri http.server contains “nginx” //过滤http头中server字段含有nginx字符的数据包 http.content_type == “text/html” //过滤content_type是text/html的http响应、post包,即根据文件类型过滤http数据包 http.content_encoding == “gzip” //过滤content_encoding是gzip的http包 http.transfer_encoding == “chunked” //根据transfer_encoding过滤 http.content_length == 279 http.content_length_header == “279″ //根据content_length的数值过滤 http.server //过滤所有含有http头中含有server字段的数据包 http.request.version == “HTTP/1.1″ //过滤HTTP/1.1版本的http包,包括请求和响应 http.response.phrase == “OK” //过滤http响应中的phrase
以content-Length
长度进行过滤,过滤语法为http.content_length == 366
所有注入成功的语句也可以从响应包查看到。
http://localhost:81/?id=1' and ascii(substring((select keyid from flag limit 0,1),1,1))=102#
这条sql语句的含义:第一个字符的ASCII码为102
>>> print(chr(102)) # 将ASCII码转换为字符 >>> f
我怎么可能一个一个查看注入成功时字符对应的ASCII值是多少呢。
0x004 脚本编写
将上面过滤后的结果导出
使用正则过滤出注入语句和字符对应的ASCII码
import re number = [] with open("aa.txt","r",encoding="utf-8") as f: for i in f.readlines(): flag_number = re.findall(r"/[Request URI: .*?=(/d+)%23/]",i,re.S) # 字符对应的ASCII码 url_list = re.findall(r"/[Request URI: (.*?)/]",i,re.S) # 注入的url if flag_number: print(url_list) number.append(flag_number[0])
这里注意注入语句成功的先后顺序,也就是上图圈出来的地方按顺序排序(从第1个字符开始判断,一直到38个字符),就是注入成功的执行流程。
知道了字符对应的ASCII码,反过来通过ASCII码得出对应的字符即可。
最后跑出flag
import re number = [] with open("aa.txt","r",encoding="utf-8") as f: for i in f.readlines(): flag_number = re.findall(r"/[Request URI: .*?=(/d+)%23/]",i,re.S) url_list = re.findall(r"/[Request URI: (.*?)/]",i,re.S) if flag_number: print(url_list) number.append(flag_number[0]) print(number) flag = '' for i in number: flag +=chr(int(i)) print(flag)
到此,关于“Wireshark分析出攻击者sql注入时查询了哪些数据”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
原创文章,作者:Maggie-Hunter,如若转载,请注明出处:https://blog.ytso.com/230071.html