0x01 工具介绍
Swagger API Exploit 是一款用于检测 Swagger REST API 安全漏洞的工具。它能自动扫描 API 接口,分析敏感参数,检测未授权访问和认证绕过漏洞。该工具支持生成本地 Swagger UI,帮助用户测试接口,还能解决 CORS 问题,并在发现认证绕过时修复路径。新增了对 OpenAPI 3.0 的支持,适用于加强 API 的安全性,避免信息泄露和潜在攻击。
下载地址在末尾
0x02 功能简介
主要功能有:
-
遍历所有API接口,自动填充参数 -
尝试 GET / POST 所有接口,返回 Response Code / Content-Type / Content-Length ,用于分析接口是否可以未授权访问利用 -
分析接口是否存在敏感参数,例如url参数,容易引入外网的SSRF漏洞 -
检测 API认证绕过漏洞 -
在本地监听一个Web Server,打开Swagger UI界面,供分析接口使用 -
使用Chrome打开本地Web服务器,并禁用CORS,解决部分API接口无法跨域请求的问题 -
当工具检测到HTTP认证绕过漏洞时,本地服务器拦截API文档,修改path,以便直接在Swagger UI中进行测试
扫描器改进建议
分析json文档,将发现的URL,自动添加到爬虫中
0x03更新说明
增加支持 OpenAPI 3.0
0x04 使用介绍
-
扫描所有API集,打开Swagger UI
python swagger-exp.py http://site.com/swagger-resources/
-
扫描一个API集,打开Swagger UI
python swagger-exp.py http://site.com/v2/api-docs
-
只打开Swagger UI,不扫描接口
python swagger-exp.py
Swagger 未授权访问地址存在以下默认路径:
/api
/api-docs
/api-docs/swagger.json
/api.html
/api/api-docs
/api/apidocs
/api/doc
/api/swagger
/api/swagger-ui
/api/swagger-ui.html
/api/swagger-ui.html/
/api/swagger-ui.json
/api/swagger.json
/api/swagger/
/api/swagger/ui
/api/swagger/ui/
/api/swaggerui
/api/swaggerui/
/api/v1/
/api/v1/api-docs
/api/v1/apidocs
/api/v1/swagger
/api/v1/swagger-ui
/api/v1/swagger-ui.html
/api/v1/swagger-ui.json
/api/v1/swagger.json
/api/v1/swagger/
/api/v2
/api/v2/api-docs
/api/v2/apidocs
/api/v2/swagger
/api/v2/swagger-ui
/api/v2/swagger-ui.html
/api/v2/swagger-ui.json
/api/v2/swagger.json
/api/v2/swagger/
/api/v3
/apidocs
/apidocs/swagger.json
/doc.html
/docs/
/druid/index.html
/graphql
/libs/swaggerui
/libs/swaggerui/
/spring-security-oauth-resource/swagger-ui.html
/spring-security-rest/api/swagger-ui.html
/sw/swagger-ui.html
/swagger
/swagger-resources
/swagger-resources/configuration/security
/swagger-resources/configuration/security/
/swagger-resources/configuration/ui
/swagger-resources/configuration/ui/
/swagger-ui
/swagger-ui.html
/swagger-ui.html#/api-memory-controller
/swagger-ui.html/
/swagger-ui.json
/swagger-ui/swagger.json
/swagger.json
/swagger.yml
/swagger/
/swagger/index.html
/swagger/static/index.html
/swagger/swagger-ui.html
/swagger/ui/
/Swagger/ui/index
/swagger/ui/index
/swagger/v1/swagger.json
/swagger/v2/swagger.json
/template/swagger-ui.html
/user/swagger-ui.html
/user/swagger-ui.html/
/v1.x/swagger-ui.html
/v1/api-docs
/v1/swagger.json
/v2/api-docs/v3/api-docs
0x05 下载
https://github.com/lijiejie/swagger-exp
原文始发于微信公众号(渗透安全HackTwo):一款Swagger API漏洞利用工具Swagger API Exploit 1.2更新|漏洞探测
免责声明:文章中涉及的程序(方法)可能带有攻击性,仅供安全研究与教学之用,读者将其信息做其他用途,由读者承担全部法律及连带责任,本站不承担任何法律及连带责任;如有问题可邮件联系(建议使用企业邮箱或有效邮箱,避免邮件被拦截,联系方式见首页),望知悉。
- 左青龙
- 微信扫一扫
-
- 右白虎
- 微信扫一扫
-
评论