awd工具开发&使用说明
文章演示版本:V3.1.2
最新版本:V3.1.2
最后更新日期:2025/01/05
目标生成
使用场景:在目标扫描前如果没有下发靶机地址列表,则需要自己生成一份去扫描
ip段生成
使用场景:裁判给了一个C段(192.168.10.0),所有队伍的靶机都在这个C段中,具体ip需要自己发现
输入192.168.10.*
又或者是10.10.*.1
(用*占位)即可在程序当前运行目录下生成一个ip.txt
1 |
|
单ip多端口生成
使用场景:某些小型比赛或训练赛,为了节约资源将所有靶机映射在同一台服务器的不同端口上
同样的会在程序运行目录下生成ip.txt
1 |
|
bugku专用
使用场景:针对线上的域名生成 例如 192-168-1-X.pvp3553.bugku.cn
按以下规则输入即可,{}
中表示生成的范围,以-
分割
1 |
|
在当前目录下生成ip.txt
1 |
|
目标扫描
使用场景:自己生成靶机地址或通过平台下载后,进行特征扫描来识别题目
web靶机扫描
先打开自己的web靶机,输入网页上可以看到的特征即可
pwn靶机扫描
pwn靶机也是同理,先连上自己的看看会输出什么就填什么
写入不死马
使用场景:发现题目的默认后门或者rce点后写入不死马
在可以rce的参数后加*
,多个参数用&连接
代码执行:根据shell中的代码(例如eval或者system)来使用不同的payload
非常规路径:对于网站目录不是常规的/var/www/html
的情况下或者网站根目录没有写权限时
使用,左框填绝对路径(需要可写),右框填在网页中的体现。
例如现在有一个网站结构如下
1 |
|
并且根目录不可写
那么就左框需要填写/wwwroot/upload
右框需要填写/upload/
默认马
通过Get传参的默认后门写入不死马:
通过Post传参的默认后门写入不死马:
通过Header传参的默认后门写入不死马:
同时会在当前目录下生成一个shell.txt
来保存记录
自定义不死马
使用场景:想写入自己自定义的不死马
当勾选这个功能后,可以自定义不死马的内容
例如一个不死马如下,密码是123456,访问的文件名是.666.php
1 |
|
使用前需要base64编码一次(工具页中提供base64加解密功能)
1 |
|
随机文件名
使用场景:防止其他队伍监控流量进行蹭车
勾选后写入的shell的文件名,密码,连接参数随机产生
会在当前目录下生成random.txt
来保存shell记录
执行命令
使用场景:通过不死马或者其他漏洞点进行命令执行
一般shell执行命令
通过随机马执行命令
获取flag
使用场景:批量获取窗口中的flag(通用。如果在其他页面也获取到了flag也可以使用此功能)
需要先通过执行cat /flag
或curl
获取到flag
点击获取flag按钮后,程序会自动在返回的结果中搜索包含flag{}
的值并保存到flag.txt
中
如果flag格式并不是flag{}
,则可以自定义匹配的正则表达式
提交flag
使用场景:批量获取到flag后自动访问提交接口进行提交flag
flag用*占位。多个参数用&分割。注意在设置页中设置线程数或者选择延时(选择延时后线程失效),太大容易丢包
Get方式:http://192.168.100.103:4444/api/flag?token=xxxx&flag=xxxx
Post方式:
ssh
使用场景:ssh弱口令
比如裁判下发的ssh地址为x.x.x.x:2222 密码:ctf@awd
,就可以知道所有队伍都是这个密码。而且有些比赛不设置防御时间,一开始就能连到其他队伍的ssh(这里就不得不提到某年的宁波市awd)
ssh扫描
扫描结果会保存在ssh.txt
ssh密码更改
密码的复杂度有一定要求(看靶机的环境),建议设置的复杂一点
多人
使用场景:离线环境下 局域网中队友的信息传递
其中A先当服务端(需要先在设置中设置好参数)
然后A点击启动服务
其余队友B和C当客户端(同样要先在设置中设置好参数)
B和C设置好后点击连接服务即可
A B C 多人交互效果
主动点击断开效果
自定义
使用场景:1:批量发送一些请求,例如批量上传文件。2:提交flag。3:执行简单的pwn攻击
执行自定义请求
提交flag
如果觉得提交flag的参数过于多,又或者根本没有api接口的奇安信平台。就可以抓包后在这提交
将flag的位置替换成{{{flag}}}
即可,程序会自动读取软件运行目录下的flag.txt进行替换
1 |
|
执行简单的pwn攻击
可以执行简单的脚本(没有经过实战测试,所以可能有些bug)
例子如下,需要注意的是要选择 安装过脚本中导入的库的 python路径
如果没有自动识别到,也可以手动更改路径
1 |
|
然后可以使用执行命令页面的获取flag来提取flag(这个功能是通用的,只要有flag出现在屏幕内)
定时任务
使用场景:解放双手,自动运行
在写入不死马,执行命令,提交flag三处可以选择定时执行任务,最短1分钟执行一次
使用方法与正常操作一样,填完参数后点击定时按钮并选择时间即可
需要注意的是,目前实现的方式是定时点击按钮,所以填入的内容不要在运行期间更改,否则会执行失败
如果想取消可以关闭程序或者在全局设置中点击 管理定时任务 按钮
运行结果会保存在log/task_log.txt
注意:此功能应谨慎使用,防止发送网络流量过大!!!注意观察 shell.txt 和 task_log.txt 的内容
工具&设置
使用场景:base64,url的编码与解码,行去重与清屏
支持拖放文件
全局设置中可以切换线程数量和超时时间,并且可以选择是否记录错误日志
笔记
使用场景:在离线环境下提供一些命令,仅供参考!!
更新日志
V1.0.0:初始版本
V1.1.0:添加多种扫描方式,代码逻辑优化
V1.2.0:添加随机不死马功能,修复诺干bug
V2.1.0:整体70%代码重构(扫描速度较上一代提升11倍)。新增ssh模块和设置模块
V2.1.1:优化不死马的判断逻辑
V2.2.0:新增局域网多人聊天模块
V2.2.1:修复了若干BUG
V2.2.2:更新ui,新增自定义请求包模块
V2.2.3:添加全局超时时间设置,优化写入不死马模块(区分代码执行和命令执行,适应tp框架路径)
V3.0.0:新增一机一码,添加记录错误日志功能,优化写入不死马/执行命令的逻辑
V3.0.1:部分代码结构优化,添加定时任务功能
V3.1.0:优化ip生成功能,添加head执行命令功能,优化复杂路径的适配,优化冗余代码
V3.1.1:优化自定义模块(集成简单的pwn批量脚本执行/自识别flag),新增笔记模块,优化总体使用体验
V3.1.2:添加进度提示,修复一个严重BUG,增加新logo
同时感谢以下师傅对AWD_RAH提出的建议
@Datch (定时运行)
@liangmo (head头一句话)
@淡灬看夏丶恋雨(a13niL) (笔记功能)
@蓝猫少爷 (另一种提交flag的方式)