mitmproxy 是一个支持 HTTP 和 HTTPS 的抓包程序,类似 Fiddler、Charles 的功能,只不过它是一个控制台的形式操作。
同时 mitmproxy 还有两个关联组件,一个是 mitmdump,它是 mitmproxy 的命令行接口,利用它我们可以对接 Python 脚本,用 Python 实现监听后的处理。另一个是 mitmweb,它是一个 Web 程序,通过它我们可以清楚地观察到 mitmproxy 捕获的请求。
本节我们来了解一下 mitmproxy、mitmdump、mitmweb 的安装方式。
相关链接
- GitHub:https://github.com/mitmproxy/mitmproxy
- 官方网站:https://mitmproxy.org
- PyPi:https://pypi.python.org/pypi/mitmproxy
- 官方文档:http://docs.mitmproxy.org
- mitmdump 脚本:http://docs.mitmproxy.org/en/stable/scripting/overview.html
- 下载地址:https://github.com/mitmproxy/mitmproxy/releases
- DockerHub:https://hub.docker.com/r/mitmproxy/mitmproxy
pip 安装
最简单的安装方式还是使用 pip,直接执行如下命令即可安装:
1 |
pip3 install mitmproxy |
这是最简单和通用的安装方式,执行完毕之后即可完成 mitmproxy 的安装,另外还安装了 mitmdump、mitmweb 两个组件,如果不想用此种方式安装也可以选择下文列出的专门针对各个平台的安装方式或者 Docker 安装方式。
Windows 下的安装
可以到 https://mitmproxy.org/ 获取安装包,如图所示:
下载之后直接双击安装包即可安装。
注意在 Windows 上不支持 mitmproxy 的控制台接口,但是可以使用 mitmdump 和 mitmweb。
Linux 下的安装
Linux 可以下载编译好的二进制包,此发行包一般是最新版本,它包含了最新版本的 mitmproxy 和内置的 Python3 环境还有最新的 OpenSSL 环境。
如果你的环境里没有 Python3 和 OpenSSL 环境,建议使用此种方式安装,如图所示,下载安装包即可:
下载之后需要解压然后将其配置到环境变量。
1 |
tar -zxvf mitmproxy-*-linux.tar.gz |
这样就可以将三个可执行文件移动到了 /usr/bin 目录,而一般 /usr/bin 目录都已经配置在了环境变量下,所以接下来我们就可以直接调用这三个工具了。
Mac 下的安装
Mac 的安装非常简单,使用 HomeBrew 即可,命令如下:
1 |
brew install mitmproxy |
执行命令后即可完成 mitmproxy 的安装。
Docker 安装
mitmproxy 也支持 Docker,其 Docker Hub 的地址为:https://hub.docker.com/r/mitmproxy/mitmproxy/
Docker 下 mitmproxy 的安装命令为:
1 |
docker run --rm -it -p 8080:8080 mitmproxy/mitmproxy mitmdump |
这样就在 8080 端口上启动了 mitmproxy 和 mitmdump。
如果想要获取 CA 证书,可以选择挂载磁盘选项,命令如下:
1 |
docker run --rm -it -v ~/.mitmproxy:/home/mitmproxy/.mitmproxy -p 8080:8080 mitmproxy/mitmproxy mitmdump |
这样可以在 ~/.mitmproxy 目录找到 CA 证书。
另外还可以在 8081 端口上启动 mitmweb,命令如下:
1 |
docker run --rm -it -p 8080:8080 -p 127.0.0.1:8081:8081 mitmproxy/mitmproxy mitmweb |
更多启动方式可以参考 Docker Hub 的安装说明。
证书配置
对于 mitmproxy 来说,如果想要截获 HTTPS 请求,我们就需要设置证书,mitmproxy 在安装后会提供一套 CA 证书,只要客户端信任了 mitmproxy 提供的证书,我们就可以通过 mitmproxy 获取 HTTPS 请求的具体内容,否则 mitmproxy 是无法解析 HTTPS 请求的。
首先运行一下命令产生 CA 证书,启动 mitmdump 即可:
1 |
mitmdump |
这样即可启动 mitmdump,接下来我们就可以在用户目录下的 .mitmproxy 目录里面找到 CA 证书,如图所示:
证书一共五个,下面是对这五个证书的说明:
名称 | 描述 |
---|---|
mitmproxy-ca.pem | PEM 格式的证书私钥 |
mitmproxy-ca-cert.pem | PEM 格式证书,适用于大多数非 Windows 平台 |
mitmproxy-ca-cert.p12 | PKCS12 格式的证书,适用于 Windows 平台 |
mitmproxy-ca-cert.cer | 与 mitmproxy-ca-cert.pem 相同,只是改变了后缀,适用于部分 Android 平台 |
mitmproxy-dhparam.pem | PEM 格式的秘钥文件,用于增强 SSL 安全性 |
下面我们介绍一下 Windows、Mac、iOS、Android 平台下的证书配置过程。
Windows
双击 mitmproxy-ca.p12,就会出现导入证书的引导页,如图所示:
直接点击下一步即可,接下来会出现密码设置提示,如图所示:
不需要设置密码,直接点击下一步即可。
接下来需要选择证书的存储区域,如图所示:
点击第二个选项“将所有证书放入下列存储”,然后点击浏览,再选择证书存储位置为“受信任的根证书颁发机构”,确定,点击下一步。
最后如果有安全警告均点击“是”即可,如图所示:
这样就配置完成 Windows 下信任 CA 证书了。
Mac
Mac 下双击 mitmproxy-ca-cert.pem 即可弹出钥匙串管理页面,然后找到 mitmproxy 证书,点击打开其设置选项,选择始终信任即可,如图所示:
这样就配置完成 Mac 下信任 CA 证书了。
iOS
将 mitmproxy-ca-cert.pem 文件发送到 iPhone 上,推荐使用邮件的方式发送,iPhone 上可以直接点击附件并识别安装,如图所示:
点击之后会跳到安装描述文件的页面,点击右上角的安装按钮即可安装,此处会有警告提示,如图所示:
继续点击右上角的安装即可,安装成功之后会有已安装的提示,如图所示:
如果你的 iOS 版本是 10.3 以下的话,此处信任 CA 证书的流程就已经完成了。
如果你的 iOS 版本是 10.3 及以上,还需要在设置->通用->关于本机->证书信任设置将证书添加完全信任,如图所示:
在这里将 mitmproxy 的完全信任开关打开即可。
这样 iOS 上配置信任 CA 证书的流程就结束了。
Android
Android 手机同样需要将证书 mitmproxy-ca-cert.pem 文件发送到手机上,例如直接拷贝文件。
接下来点击证书便会出现一个提示窗口,如图所示:
这时输入证书的名称,然后点击确定即可完成安装。
结语
本节我们了解了 mitmproxy、mitmdump、mitmweb 的安装方式。