OneScan 插件的思路由 One 哥提供,我负责将 One 哥的思路进行编码变现。插件起初是为了发现站点深层目录下的 Swagger-API
接口文档,后面随着功能的完善和使用姿势的增加,目前可以完成:发现隐藏接口、发现敏感信息泄漏、测试未授权、越权接口等测试工作
参与开发人员:
- 主要开发: vaycore
- 后续更新功能: Rural.Dog
- 产品经理: 0ne_1
例如配置 Payload 字典如下:
/api-docs
/{{domain.name}}.zip
目标站点访问:https://www.xxxxxx.com/a/b/c/xxx.min.js
,插件会自动扫描如下的路径:
https://www.xxxxxx.com/api-docs
https://www.xxxxxx.com/xxxxxx.zip
https://www.xxxxxx.com/a/api-docs
https://www.xxxxxx.com/a/xxxxxx.zip
https://www.xxxxxx.com/a/b/api-docs
https://www.xxxxxx.com/a/b/xxxxxx.zip
https://www.xxxxxx.com/a/b/c/api-docs
https://www.xxxxxx.com/a/b/c/xxxxxx.zip
BurpSuite 安装流程如下(不同版本可能有所差异):
Extender -> Extensions -> Add -> Select File -> Next
Extensions -> Installed -> Add -> Select File -> Next
流程结束后,打印如下信息表示插件安装完成(需要在 Config -> Other -> HaE 中配置 HaE 插件 JAR 包路径后,才会显示 HaE 插件的日志信息、数据高亮功能):
插件配置文件默认存放路径如下(优先检测当前插件 JAR 包所在目录下是否存在 OneScan
目录,如果存在,将使用该目录作为工作目录;否则,使用如下路径作为工作目录):
linux、macOS:
~/.config/OneScan/
windows:
C:\Users\<用户名>\.config\OneScan\
可以从 BurpSuite 其它位置发送到 OneScan 主动扫描
可以使用已配置的字典发送到 OneScan 主动扫描(存在1个以上的字典配置才会显示该菜单):
提取请求和响应包中 JSON 格式的字段,插件 1.0.0
版本新增 Fingerprint
指纹信息展示
目前支持的动态变量如下(以目标:http://www.xxxxxx.com:81/path/to/index.html
为例,日期和时间以:2030-08-09 07:08:09
为例):
{{host}} - 请求头中的Host(格式:www.xxxxxx.com:81)
{{domain}} - 请求头中不包含端口号的Host(格式:www.xxxxxx.com)
{{domain.main}} - 主域名(格式:xxxxxx.com;如果是IP地址或无效格式,会自动跳过这条Payload)
{{domain.name}} - 主域名的名称(格式:xxxxxx;如果是IP地址或无效格式,会自动跳过这条Payload)
{{protocol}} - 请求头中的协议(格式:http)
{{timestamp}} - Unix时间戳(单位:秒)
{{random.ip}} - 随机IPv4值
{{random.local-ip}} - 随机内网IPv4值
{{random.ua}} - 随机UserAgent值,随机源可配置
{{subdomain}} - 子域名动态变量(格式:www;只有主域名时:`xxxxxx.com` => `xxxxxx`)
{{webroot}} - 一级目录动态变量(格式:path;不存在一级目录时,会自动跳过这条Payload)
{{date.yyyy}} - 日期:年(格式:2030)
{{date.MM}} - 日期:月(格式:08)
{{date.dd}} - 日期:日(格式:09)
{{date.yy}} - 日期:年(格式:30)
{{date.M}} - 日期:月(格式:8)
{{date.d}} - 日期:日(格式:9)
{{time.HH}} - 时间:小时(格式:07)
{{time.mm}} - 时间:分钟(格式:08)
{{time.ss}} - 时间:秒(格式:09)
{{time.H}} - 时间:小时(格式:7)
{{time.m}} - 时间:分钟(格式:8)
{{time.s}} - 时间:秒(格式:9)
插件数据看板说明如下
Listen Proxy Message
开关被动扫描(默认禁用),代理的请求包都会经过 OneScan 插件(建议配置白名单后启用)Remove Header
开关移除请求头(默认禁用),根据Request -> Remove header
里的配置,移除请求头中对应的值Replace Header
开关请求头替换(默认启用),使用Request -> Header
中配置的请求头请求数据DirScan
开关递归扫描(默认启用),对目标进行递归扫描Payload Processing
开关请求包处理功能(默认启用)Filter
设置数据过滤规则Import url
导入 URL 目标扫描Stop
停止正在扫描的任务Actions
操作菜单(列表鼠标右键菜单的所有功能)
点击主面板的 Filter
按钮,打开设置过滤规则对话框(插件 0.5.2
版本新增功能)
Select column
选择要过滤的列Add filter
为选中列添加过滤条件Clear
清除选中列的所有过滤规则Reset
重置所有过滤规则Cancel
取消本次的所有变更OK
使配置的规则生效
通过右键菜单,点击 Temporarily filter selected data
添加临时过滤规则:
只支持临时添加相同值的过滤(复杂的规则,请点击 Filter
按钮处理),例如选中了 Status
是 400
和 503
的两条数据,生成的临时过滤规则示例如下:
Status != 400 && Status != 503
Payload 配置界面如下
Payload
配置递归扫描的字典Payload Processing
配置请求过程中对数据包的处理(例如:URL 添加前缀、后缀,Body 正则匹配和替换)
Request 配置界面如下
QPS
QPS 限制,限制每秒请求的数量,范围(1-9999
)Request delay
请求延时限制,限制每次请求的间隔时间,范围(0-99999
)。(单位:毫秒)Scan level
限制目录扫描层级,范围(1-99
)。限制方向:Left to right
(从左往右),Right to left
(从右往左)Retry
请求失败时重试次数配置,范围(0-9
)Include method
配置请求方法白名单Exclude suffix
排除指定后缀的数据包Header
递归扫描过程的请求头配置,可配置变量Remove header
请求时移除请求头中对应的值UserAgent
这里配置的是{{random.ua}}
变量列表里的值
Host配置界面如下
Allowlist
配置白名单列表,如果该列表不为空,插件只对匹配的 Host 进行请求Blocklist
配置黑名单列表,如果该列表不为空,插件不会向匹配的 Host 发起请求
Other配置界面如下
Maximum display length
限制请求、响应包的最大显示长度(插件1.6.11
版本新增)Collect directory
数据收集存放目录Wordlist Directory
插件1.0.0
版本新增字典管理,此目录下包含所有字典文件的配置HaE
配置 HaE 插件 JAR 包路径,与 HaE 联动,使数据看板里的敏感信息高亮Clear cache
清除指纹识别缓存(缓存用于加快指纹识别的速度)
插件 1.0.0
版本新增 Fingerprint
指纹模块,指纹管理界面如下
Reload
重新加载配置文件中的指纹信息Search
搜索指纹库中的指纹信息Add
添加指纹信息Edit
编辑选中的指纹信息Delete
删除选中的指纹信息Test
测试指纹规则
指纹信息全程使用 UI 添加,不需要编写正则匹配规则(也可以使用正则匹配),UI 界面如下:
Name
指纹名称(产品名)Company
产品公司(默认:Other)Lang
编程语言SoftHard
软硬件(0=其它;1=硬件;2=软件)Frame
产品使用的开发框架ParentCategory
父类别(默认:Other)Category
类别(默认:Other)Rules
指纹匹配规则
包含七种数据源
header
Headerserver
Header 中的 Server 值body
Body 数据title
Html 标题bodyMd5
Body 数据 MD5 值bodyHash
Body 数据 Hash 值banner
其它协议的 Banner 信息(HTTP协议无法匹配该值)
共有十种匹配方法
equals
匹配相等notEquals
匹配不相等iEquals
匹配相等(忽略大小写)iNotEquals
匹配不相等(忽略大小写)contains
包含notContains
不包含iContains
包含(忽略大小写)iNotContains
不包含(忽略大小写)regex
正则匹配notRegex
正则不匹配
插件 1.5.0
版本新增 Collect
数据收集面板,面板截图如下:
All
列出所有收集的数据JsonField
收集的 JSON 字段信息WebName
收集的 WebName 信息(例如访问:/api/v1/users
,会自动收集api
)Search
在列表中搜索对应数据(正则表达式)Reverse
反向搜索(勾选后,例如搜索:a
,列表中不会出现包含a
的数据)Ignore Case
忽略大小写
将如下数据包主动发送到 OneScan 插件扫描:
POST /mcp/pc/pcsearch HTTP/1.1
Host: ug.baidu.com
Content-Length: 56
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36
Content-Type: application/json
Accept: */*
Origin: https://www.baidu.com
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Connection: close
{"invoke_info":{"pos_1":[{}],"pos_2":[{}],"pos_3":[{}]}}
面板展示如下:
欢迎各位师傅加入 OneScan 交流群
非常感谢各位师傅的关注和支持(如果觉得项目还不错,请给项目一个 Star
吧)
- 代码写的很乱,还请师傅们见谅
- 欢迎各位师傅提交
Issues
和Pull requests
,一起完善项目