前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >如何使用mitmproxy2swagger对REST API进行逆向工程分析

如何使用mitmproxy2swagger对REST API进行逆向工程分析

作者头像
FB客服
发布2023-03-30 19:44:03
1.3K0
发布2023-03-30 19:44:03
举报
文章被收录于专栏:FreeBufFreeBuf

 关于mitmproxy2swagger 

mitmproxy2swagger是一款功能强大的逆向工程分析工具,该工具能够以自动化的形式将捕捉到的mitmproxy数据转换为符合OpenAPI 3.0规范的数据。这也就意味着,在该工具的帮助下,广大研究人员能够以自动化的形式对REST API进行逆向分析,并捕捉流量数据。

除此之外,该工具还可以支持从浏览器开发者工具导出并处理HAR文件。

 工具安装 

由于该工具基于Python 3开发,因此我们首先需要在本地设备上安装并配置好Python 3和pip 3环境。

接下来,我们可以使用下列命令直接将该项目源码克隆至本地:

代码语言:javascript
复制
git clone https://github.com/alufers/mitmproxy2swagger.git

除此之外,我们还可以通过pip或pip3来直接安装mitmproxy2swagger:

代码语言:javascript
复制
$ pip install mitmproxy2swagger
# ... 或 ...
$ pip3 install mitmproxy2swagger

 工具使用 

Mitmproxy

首先,通过运行mitmproxy工具来捕捉流量数据,我们建议大家使用mitmweb,也就是内置在mitmproxy中的一个Web接口:

代码语言:javascript
复制
$ mitmweb
Web server listening at http://127.0.0.1:8081/
Proxy server listening at http://*:9999
...

接下来,将捕捉到的流量数据存储到流文件中。在mitmweb中,我们可以点击“File”菜单,并选择“Save”:

第三步,使用下列参数命令来运行mitmproxy2swagger:

代码语言:javascript
复制
$ mitmproxy2swagger -i <path_to_mitmptoxy_flow> -o <path_to_output_schema> -p <api_prefix>

需要注意的是,我们可以直接使用已有的schema,并根据需要来进行自定义扩展。

其中的<api_prefix>是需要进行逆向工程分析的目标API的URL基地址前缀,然后可以在mitmproxy中观察请求以及响应数据。

比如说,如果一个App发送了如下所示的请求:

代码语言:javascript
复制
https://api.example.com/v1/login
https://api.example.com/v1/users/2
https://api.example.com/v1/users/2/profile

那么URL基地址前缀则为https://api.example.com/v1。

然后,在schema文件中创建如下所示的字段:

代码语言:javascript
复制
x-path-templates:
# Remove the ignore: prefix to generate an endpoint with its URL
# Lines that are closer to the top take precedence, the matching is greedy
- ignore:/addresses
- ignore:/basket
- ignore:/basket/add
- ignore:/basket/checkouts
- ignore:/basket/coupons/attach/{id}
- ignore:/basket/coupons/attach/104754

在代码编辑器中打开一个schema文件,并移除目标生成路径的“ignore:”前缀,或者在路径中添加其他的参数。

最后,运行mitmproxy2swagger即可:

代码语言:javascript
复制
$ mitmproxy2swagger -i <path_to_mitmptoxy_flow> -o <path_to_output_schema> -p <api_prefix> [--examples]

HAR

首先,从浏览器的开发者工具捕捉并导出流量。在浏览器的开发者工具中,切换到“Network”标签,并点击“Export HAR”按钮:

接下来,运行mitmproxy2swagger,工具将会自动检测HAR文件并对其进行数据分析和处理。

工具输出样例

https://github.com/alufers/mitmproxy2swagger/blob/master/example_outputs/lisek-out.swagger.yml

工具使用演示

https://user-images.githubusercontent.com/5400940/168086818-c48f60ab-3f95-42eb-b435-c8b1a6326b81.mp4

许可证协议

本项目的开发与发布遵循MIT开源许可证协议。

项目地址

https://github.com/alufers/mitmproxy2swagger

参考资料

https://mitmproxy.org/

https://swagger.io/specification/

https://github.com/alufers/mitmproxy2swagger#har

https://docs.mitmproxy.org/stable/

https://www.npmjs.com/package/redoc-cli

精彩推荐

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-06-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 FreeBuf 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  •  关于mitmproxy2swagger 
  •  工具安装 
  •  工具使用 
    • Mitmproxy
    • 工具输出样例
    • 工具使用演示
    • 许可证协议
    • 项目地址
    • 参考资料
    相关产品与服务
    云开发 CLI 工具
    云开发 CLI 工具(Cloudbase CLI Devtools,CCLID)是云开发官方指定的 CLI 工具,可以帮助开发者快速构建 Serverless 应用。CLI 工具提供能力包括文件储存的管理、云函数的部署、模板项目的创建、HTTP Service、静态网站托管等,您可以专注于编码,无需在平台中切换各类配置。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档