mitmproxy 抓包神器-6.如何在linux操作系统中安装

上海-悠悠 / 2024-02-26 / 原文

前言

常见的抓包工具有fiddler 和 charles, 这些工具都是需要安装本地客户端,python 版的抓包工具可以用 mitmproxy。
mitmproxy 相比Charles、fiddler的优点在于,它可以命令行方式或脚本的方式启动服务,跨平台使用。

Linux 环境安装

mitmproxy(man-in-the-middle attack proxy),中间人攻击工具,可以用来拦截、修改、保存 HTTP/HTTPS 请求
官方文档地址https://docs.mitmproxy.org/stable/
mitmproxy 工具有以下三个组件构成

  • mitmproxy 是具有 SSL/TLS 功能的交互式拦截侦听代理,具有用于HTTP/1,HTTP/2和WebSockets的控制台界面。
  • mitmweb 是用于 mitmproxy 的基于 Web 的界面, 提供一个可视化界面帮助我们查看抓取的请求,可以修改返回内容。
  • mitmdump 它是mitmproxy的命令行接口,利用它我们可以对接Python脚本,用Python实现监听后的处理。

先pip安装mitmproxy

pip3.9 install mitmproxy

我用的python3.9版本,安装的mitmproxy 9.1版本

[root@xx]# pip3.9 show mitmproxy
Name: mitmproxy
Version: 9.0.1
Summary: An interactive, SSL/TLS-capable intercepting proxy for HTTP/1, HTTP/2, and WebSockets.
Home-page: http://mitmproxy.org
Author: Aldo Cortesi
Author-email: aldo@corte.si

启动服务

输入 mitmproxy 命令即可启动服务,监听端口是8080

mitmweb 是用于 mitmproxy 的基于 Web 的界面, 提供一个可视化界面帮助我们查看抓取的请求,可以修改返回内容

[root@xx]# mitmweb 
[11:48:37.804] HTTP(S) proxy listening at *:8080.
[11:48:37.805] Web server listening at http://127.0.0.1:8081/
[11:48:37.866] No web browser found. Please open a browser and point it to http://127.0.0.1:8081/

默认监听端口是8080, web访问服务地址:http://服务ip:8081/

这里的服务器ip是内网ip, 也就是通过 ifconfig 查看到的,必须你的本机和 linux 服务器都是一个局域网的才可以
(如果服务器是阿里云,腾讯云等这种服务器,需带上block_global启动参数:mitmweb --set block_global=false,并开放访问端口权限)

Chrome 浏览器代理插件 SwitchyOmega 安装与使用

新增情景模式-代理服务器-点应用选项保存

浏览器设置切换到代理服务访问网站

安装https 证书

mitmproxy 默认只抓取http的请求,https 的请求需要安装证书
上一步浏览器使用代理后,访问http的请求是可以正常访问的,当访问https的请求,比如https://www.baidu.com/

看到如上提示,说明代理设置成功了。