内容简介:Author: Vulkey_ChenBlog: gh0st.cn之前两篇文章中已经记录过了payloads和printers模块,所以就不在这继续记录。
Wfuzz高阶功法
Author: Vulkey_Chen
Blog: gh0st.cn
模块
之前两篇文章中已经记录过了payloads和printers模块,所以就不在这继续记录。
Iterators
BurpSuite的 Intruder
模块中Attack Type有Sniper(狙击手)、Battering ram(撞击物)、Pitchfork(相交叉)、Cluster bomb(集束炸弹)~
wfuzz也可以完成这样的功能,将不同的字典的组合起来,那就是 Iterators
模块。
使用参数 -m 迭代器
,wfuzz自带的迭代器有三个: zip
、 chain
、 product
,如果不指定迭代器,默认为 product
迭代器。
zip
命令:
wfuzz -z range,0-9 -w dict.txt -m zip http://127.0.0.1/ip.php?FUZZ=FUZ2Z
结果如下:
该命令的意思:设置了两个字典。两个占位符,一个是 range
模块生成的 0、1、2、3、4、5、6、7、8、9
10个数字,一个是外部字典dict.txt的9行字典,使用 zip迭代器组合这两个字典 发送。
zip迭代器的功能:字典数相同、一一对应进行组合, 如果字典数不一致则多余的抛弃掉不请求,如上命令结果就是数字9倍抛弃了因为没有字典和它组合 。
chain
命令:
wfuzz -z range,0-9 -w dict.txt -m chain http://127.0.0.1/ip.php?FUZZ
结果如下:
该命令设置了两个字典,一个占位符FUZZ, 使用chain迭代器组合这两个字典 发送。
chain迭代器的功能:通过返回结果就能看出来 chain
迭代器的功能了, 这个迭代器是将所有字典全部整合(不做组合)放在一起然后传入占位符FUZZ 中。
product
命令:
wfuzz -z range,0-2 -w dict.txt -m product http://127.0.0.1/ip.php?FUZZ=FUZ2Z
结果如下:
该命令的意思:设置了两个字典,两个占位符,一个是 range
模块生成的 0、1、2
3个数字,一个是外部字典dict.txt的3行字典,使用 product迭代器组合这两个字典 发送。
product迭代器的功能:通过返回结果,知道了请求总数为9,请求的payload交叉组合:
Encoders
wfuzz中 encoders模块 可以实现编码解码、加密,它支持如下图中所列转换功能:
使用Encoders
正常使用:
-
wfuzz -z file --zP fn=wordlist,encoder=md5 URL/FUZZ
看过第一章的应该都能理解意思了,这里新增的就是
encoder=md5
,也就是使用Encoders
的md5
加密。 -
wfuzz -z file,wordlist,md5 URL/FUZZ
这里简写了第一条命令,一般都使用这条命令来调用Encoders
使用多个Encoder:
-
多个转换,使用一个
-
号分隔的列表来指定wfuzz -z file,dict.txt,md5-base64 http://127.0.0.1/ip.php\?FUZZ
-
多次转换,使用一个
@
号分隔的列表来按照 从右往左顺序 多次转换(这里让传入的字典先md5加密然后base64编码)wfuzz -z file,dict.txt,base64@md5 http://127.0.0.1/ip.php\?FUZZ
Scripts
之前说了wfuzz支持插件,其本身也有很多插件,插件大部分都是实现扫描和解析功能,插件共有两大类和一类附加插件:
- passive:分析已有的请求和响应(被动)
-
active:会向目标发送请求来探测(主动)
- discovery:自动帮助wfuzz对目标站进行爬取,将发现的内容提供给wfuzz进行请求
Wfuzz默认自带脚本如下:
使用Scripts
我想使用 Scripts
中的 backups
模块,可以先试用 --script-help
参数来看如何关于这个模块的信息:
wfuzz --script-help=robots
从如上结果中可以知道这个模块不需要设置参数,该模块解析robots.txt的并且寻找新的内容,,至于到底寻找什么,就需要动手实践下了~
在本地建一个robots.txt:
使用如下命令:
wfuzz --script=robots -z list,"robots.txt" http://127.0.0.1/FUZZ
--script
是使用脚本模块的参数,这时候就有个疑惑命令为什么要加上list呢?因为在这里 robots
脚本只是解析 robots.txt
规则的,所以你需要告诉wfuzz去请求哪个文件而这里我写的就是 robots.txt
就可以解析(假设 http://127.0.0.1/t.txt 的内容也是robots的就可以写成这样的命令 wfuzz --script=robots -z list,"t.txt" http://127.0.0.1/FUZZ
)
从如上图中得知wfuzz解析robots.txt的内容然后请求解析之后获得的路径。
自定义插件
使用wfuzz可以自己编写wfuzz插件,需要放在 ~/.wfuzz/scripts/
目录下,具体如何编写可以参考已有的插件:https://github.com/xmendez/wfuzz/tree/master/src/wfuzz/plugins/scripts
技巧
Recipes
Wfuzz可以生成一个recipes用来保存命令,方便下次执行或者分享给别人。
生成一个recipes:
wfuzz --script=robots -z list,"robots.txt" --dumo-recipe outrecipe URL/FUZZ
使用某个recipes:
wfuzz --recip outrecipe
网络异常
Wfuzz扫描的时候出现网络问题,如DNS解析失败,拒绝连接等时,wfuzz会抛出一个异常并停止执行使用 -Z
参数即可忽略这些错误继续执行。
出现错误的payload会以返回码 XXX
来表示, Payload中还有出现的错误信息 。
超时
使用wfuzz扫描会遇到一些响应很慢的情况,wfuzz可以设置超时时间。
参数 --conn-delay
来设置wfuzz等待服务器响应接连的秒数。 参数 --req-delay
来设置wfuzz等待响应完成的最大秒数。
结合BurpSuite
从Burp的LOG文件中获取测试的URL地址:
wfuzz -z burplog,"1.burp" FUZZ
还有能够读取burpsuite保存的state:
wfuzz -z burpstate,a_burp_state.burp FUZZ
过滤器
这里篇幅太长,建议综合参考 https://github.com/xmendez/wfuzz/blob/18a83606e3011159b4b2e8c0064f95044c3c4af5/docs/user/advanced.rst 就不一一写出来了。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
白话机器学习算法
[新加坡] 黄莉婷、[新加坡] 苏川集 / 武传海 / 人民邮电出版社 / 2019-2 / 49.00元
与使用数学语言或计算机编程语言讲解算法的书不同,本书另辟蹊径,用通俗易懂的人类语言以及大量有趣的示例和插图讲解10多种前沿的机器学习算法。内容涵盖k均值聚类、主成分分析、关联规则、社会网络分析等无监督学习算法,以及回归分析、k最近邻、支持向量机、决策树、随机森林、神经网络等监督学习算法,并概述强化学习算法的思想。任何对机器学习和数据科学怀有好奇心的人都可以通过本书构建知识体系。一起来看看 《白话机器学习算法》 这本书的介绍吧!