唯快不破的分块传输绕WAF

访客4年前关于黑客接单1197

前言

某重保项目,需要进行渗透,找到突破口,拿起sqlmap一顿梭,奈何安全设备在疯狂运转,故祭起绕过注入的最强套路-分块传输绕过WAF进行SQL注入。安全人员当然安全之一,拿到渗透授权书,测试时间报备等操作授权后:

神马探测

因为客户授权的是三个段,资产众多,且时间紧张,多工具搭配同时进行资产探测。故先对三个段使用资产探测神器goby和端口神器nmap一顿怼,还有静悄悄不说话的主机漏扫神器Nessus。因此也就结合探测出来的ip和端口及其他资产详情,信息探测进行时,先根据目前得到的web网站一顿梭。在浏览器输入IP+端口,滴,开启web世界。喝了一口肥宅快乐水并 *** 眼开始端详起这几个web网站。

界面是这个样子:

定睛一看,先抓个包跑跑注入,神器sqlmap一片红。卒,遂放弃。

再次定睛一看,妥妥的用户登录页面,试试弱口令,burp神器走一波。

嗯,用户名密码可爆破漏洞,提交,收工。

报告提交后,我领导看到后,嗯,如下图:

挨了一顿锤之后,手里的肥宅快乐水不香了,继续努力搬砖吧。

继续杠不要怂

作为男子汉,肿么能因为sqlmap一片红就继续放弃呢?是男人就继续用sqlmap杠,这次祭起分块WAF进行绕过。

what is 分块传输?

分块传输编码(Chunked transfer encoding)是超文本传输协议(HTTP)中的一种数据传输机制,允许HTTP由应用服务器发送给客户端应用( 通常是网页浏览器)的数据可以分成多个部分。分块传输编码只在HTTP协议1.1版本(HTTP/1.1)中提供。通常,HTTP应答消息中发送的数据是整个发送的,Content-Length消息头字段表示数据的长度。数据的长度很重要,因为客户端需要知道哪里是应答消息的结束,以及后续应答消息的开始。然而,使用分块传输编码,数据分解成一系列数据块,并以一个或多个块发送,这样服务器可以发送数据而不需要预先知道发送内容的总大小。通常数据块的大小是一致的,但也不总是这种情况。

一般情况HTTP请求包的Header包含Content-Length域来指明报文体的长度。有时候服务生成HTTP回应是无法确定消息大小的,比如大文件的下载,或者后台需要复杂的逻辑才能全部处理页面的请求,这时用需要实时生成消息长度,服务器一般使用chunked编码。在进行Chunked编码传输时,在回复消息的Headers有Transfer-Encoding域值为chunked,表示将用chunked编码传输内容。

这在http协议中也是个常见的字段,用于http传送过程的分块技术,原因是http服务器响应的报文长度经常是不可预测的,使用Content-length的实体搜捕并不是总是管用。

分块技术的意思是说,实体被分成许多的块,也就是应用层的数据,TCP在传送的过程中,不对它们做任何的解释,而是把应用层产生数据全部理解成二进制流,然后按照MSS的长度切成一分一分的,一股脑塞到tcp协议栈里面去,而具体这些二进制的数据如何做解释,需要应用层来完成。

简而言之,就是把数据包分成一块一块的丢过去,骗骗死脑筋的WAF。

分块传输开启绕过

手工进行分块绕过较为繁琐,且花费时间长,面对大量资产的情况,项目时间较为紧张的情况下,还是使用自动化工具来的快捷方便。这里使用sqlmap+burp+burp插件(chunked-coding-converter)。祭出我二表哥工具的项目地址:https://github.com/c0ny1/chunked-coding-converter。快速使用:burp获取post包后,复制post包,做成post.txt,并放置于sqlmap工具文件下。(忽略在下负一级的打马赛克技术)

使用burp 设定插件,开启插件 *** :

使用Sqlmap进行 *** :sqlmap语句sqlmap.py -r post.txt --proxy=http://127.0.0.1:8080--os-shell

什么?为什么不继续了?因为客户不让了,表演结束了,谢谢大家。

让我再多说一句

当然为了更加快速化,和方便快捷一步到位,可使用sqlmap参数batch自动进行注入。

sqlmap.py -r post.txt --proxy=http://127.0.0.1:8080–batch

当然,我们再可以提高速度,进行一步到位,可使用sqlmap参数threads提高并发数。

sqlmap.py -r post.txt --proxy=http://127.0.0.1:8080--batch --threads 10

当当当然可以修改sqlmap配置文件将默认更高10改成9999,具体根据现场实际情况进行修改。

Sqlmap配置文件settings.py,将MAX_NUMBER_OF_THREADS=9999。

多线程sqlmap效果如下:

Ok,以上是面对大量资产绕过waf进行注入的姿势。

相关文章

手机短信能不能查到吗(手机短信可以查吗)

手机短信能不能查到吗(手机短信可以查吗)【黑客徽信:】专业盗取微信密码,开房查询,通话记录查询,查询微信聊天记录,非常靠谱!如今,智能手机在我们的生活中扮演着非常重要的角色。许多人对手机有很强的依赖性...

现场直播(生活每天都在现场直播)

  今日听完礼品,确实被这一刻打动了。如今,许多 事儿会将我拉开。如今觉得時间非常短,彻底不足。   一天出来,我忽然发觉也没有学习培训,沒有阅读文章,沒有创作。天呀,我还没有做,可是如今我能很平静...

1分钟教你找微信号支付密码(知道手机号找微信号)

1分钟教你盗微信号交易密码(了解手机号码盗微信号) 照片来自互联网,文章内容原創,热烈欢迎关心 说到手机游戏,大部分人都喜爱玩,去工作中到三、四十岁到多少岁的小孩,正中间的年青人不是说,这仅仅手机...

又酸又好吃的零食(超市好吃的零食排行榜)

美味可口的特色小吃获得了每一个人的亲睐,变成大家赞叹不已的人间美味。不管生产制造哪一种,其调料都务必有科学研究的饮食搭配秘方,味儿务必美味可口,回味无穷绵长,味儿醇正,颜色溫暖,膨松诱惑,能勾起童年回...

黑客类小说排行榜完本,怎么找黑客定位,怎么找国外黑客

炸药木马相同也会定时查看和暗地控制服务器的通讯情况,以承认持续运转是否安全。 一切的通讯都假装成了随机网络流量,看起来并没有和暗地服务器直接联络。 该木马会和硬编码服务器与动态更新服务器进行通讯,假如...

内蒙古培养耐踩草坪标语欢迎踩踏-内蒙古培养耐踩草坪

内蒙古培养耐踩草坪标语欢迎踩踏-内蒙古培养耐踩草坪

关于草原修复一直大家很关注的一个话题,很多地方也会随处可见禁止踩踏的标语,但是近日据最新消息报道内蒙古培养耐踩草坪标语欢迎踩踏,这也让大家对这个内蒙古培养耐踩草坪充满了兴趣,那么接下来大家就随小编一起...