详解安装mitmproxy以及遇到的坑和简单用法


Posted in Python onJanuary 21, 2019

mitmproxy 是一款工具,也可以说是 python 的一个包,在命令行操作的工具。

MITM 即中间人攻击(Man-in-the-middle attack)

详解安装mitmproxy以及遇到的坑和简单用法

使用这个工具可以在命令行上进行抓包,还可以对所抓到的包进行脚本处理,非常有用。

安装 mitmproxy

安装这个我们必须先安装了 pip。 pip 在安装了 python之后自带的,如果你安装了 python 就可以忽略了,如何安装这里就不说了,只说安装 mitmproxy

打开命令行,输入 pip install mitmproxy 即可

详解安装mitmproxy以及遇到的坑和简单用法

按下回车即可下载

但是到最后下载失败

error: Microsoft Visual C++ 14.0 is required. Get it with “Microsoft Visual C++ Build Tools”: http://landinghub.visualstudio.com/visual-cpp-build-tools

是因为安装这个包的 window 系统需要首先安装 Microsoft Visual C++ V14.0以上 才行。

可以在https://visualstudio.microsoft.com/zh-hans/downloads/直接下载即可,安装之后需要把 c++ de 库之类的东西都安装了,然后再在命令行进行安装 mitmproxy即可。

安装完之后查看 mitmproxy版本

命令行输入 mitmproxy --version

详解安装mitmproxy以及遇到的坑和简单用法

显示错误,这是因为 window操作系统不支持使用 mitmproxy 这个命令,我们可以使用 mitmdump 或 mitmweb 代替。

详解安装mitmproxy以及遇到的坑和简单用法

这样就成功了。

如何使用 mitmproxy抓包

开启抓包:mitmdump

详解安装mitmproxy以及遇到的坑和简单用法

这样子就是开始抓包了,监听了所有的地址,端口是 8080,如果需要改端口号,可以按 ctrl + c 退出抓包,然后输入下列命令:

mitmdump -p 8889

这样子就把端口号改成 8889 了

详解安装mitmproxy以及遇到的坑和简单用法

如果需要抓手机的包的话,就需要在你连接的 wifi 修改代理

详解安装mitmproxy以及遇到的坑和简单用法

上面的主机名字是 你电脑抓包的 ip 地址,端口号是刚才设置的端口号。设置完了打开浏览器查看。

详解安装mitmproxy以及遇到的坑和简单用法

发现需证书有问题,我们还需要安装 mitmproxy 提供的证书,要不抓包失败。

安装证书:浏览器输入 mitm.it

详解安装mitmproxy以及遇到的坑和简单用法

然后根据你的手机系统进行安装即可。

然后就可以进行抓包了。在浏览器输入 baidu.com 就可以看到下面内容了。

详解安装mitmproxy以及遇到的坑和简单用法

电脑端的也是这样差不多,都是设置代理后安装证书,这里就不多说了。

抓包之后的操作

由于在 window上操作,只能使用 mitmdump 和 mitmweb这两个命令,mitmdump 命令是没有界面,只能进行默默地抓包,不能进行数据包的查看和过滤。而 mitmweb 和在一个网页上进行抓包的调试。所以下面我们用 mitmweb 来进行调试。

1.开始抓包

mitmweb -p 8889

详解安装mitmproxy以及遇到的坑和简单用法

在你输入 baidu.com 的时候就会看到这些包了。

查看包的请求信息和响应信息只需要点击相对应的包即可。其他的就不多说了。

在 mitmproxy 上运行 python脚本

mitmproxy 的强大之处就在于它能够运行 python 脚本来处理相关的请求,现在就来看看如何处理吧。

mitmdump -p 889 -s mitm.py

这个就是在抓包的同时运行了 mitm.py 的脚本了,代码是:

# 必须这样写 def request(flow): print(flow.request.headers) # 打印请求头

这个是打印抓到的请求头,方法名和参数的名称是固定的,写错了就运行不了这个脚本。

详解安装mitmproxy以及遇到的坑和简单用法

这样子就开始了,然后在手机上打开网页。

详解安装mitmproxy以及遇到的坑和简单用法

这样子就把他们的请求头给输出了。

但是输出并不明显,我们可以使用里面的一个日志模块来输出,这样子就会显示出不同的颜色了。

详解安装mitmproxy以及遇到的坑和简单用法

命令行上显示这样:

详解安装mitmproxy以及遇到的坑和简单用法

这样子就清楚多了。

除了上面的请求头,我们还可以访问他们的请求方法,请求路径等。

详解安装mitmproxy以及遇到的坑和简单用法

响应的请求也可以获取:

详解安装mitmproxy以及遇到的坑和简单用法

同样,这里的方法名和参数也是固定的,不写这个会捕捉不到。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python 时间操作例子和时间格式化参数小结
Apr 24 Python
python:socket传输大文件示例
Jan 18 Python
python按行读取文件,去掉每行的换行符\n的实例
Apr 19 Python
python之消除前缀重命名的方法
Oct 21 Python
python ChainMap的使用和说明详解
Jun 11 Python
python绘制直方图和密度图的实例
Jul 08 Python
Django admin.py 在修改/添加表单界面显示额外字段的方法
Aug 22 Python
Python安装及Pycharm安装使用教程图解
Sep 20 Python
40个你可能不知道的Python技巧附代码
Jan 29 Python
python help函数实例用法
Dec 06 Python
python可视化 matplotlib画图使用colorbar工具自定义颜色
Dec 07 Python
Selenium Webdriver元素定位的八种常用方式(小结)
Jan 13 Python
python dict 相同key 合并value的实例
Jan 21 #Python
关于python之字典的嵌套,递归调用方法
Jan 21 #Python
对python 合并 累加两个dict的实例详解
Jan 21 #Python
python去重,一个由dict组成的list的去重示例
Jan 21 #Python
Python实现计算字符串中出现次数最多的字符示例
Jan 21 #Python
python3.6数独问题的解决
Jan 21 #Python
解决python给列表里添加字典时被最后一个覆盖的问题
Jan 21 #Python
You might like
PHP执行速率优化技巧小结
2008/03/15 PHP
PHP 的ArrayAccess接口 像数组一样来访问你的PHP对象
2010/10/12 PHP
解析php中的escape函数
2013/06/29 PHP
laravel框架路由分组,中间件,命名空间,子域名,路由前缀实例分析
2020/02/18 PHP
thinkphp框架表单数组实现图片批量上传功能示例
2020/04/04 PHP
JS学习之一个简易的日历控件
2010/03/24 Javascript
ajax 缓存 问题 requestheader
2010/08/01 Javascript
基于JQuery实现相同内容合并单元格的代码
2011/01/12 Javascript
Draggable Elements 元素拖拽功能实现代码
2011/03/30 Javascript
js 编码转换 gb2312 和 utf8 互转的2种方法
2013/08/07 Javascript
JS实现让访问者自助选择网页文字颜色的方法
2015/02/24 Javascript
分享有关jQuery中animate、slide、fade等动画的连续触发、滞后反复执行的bug
2016/01/10 Javascript
仿Angular Bootstrap TimePicker创建分钟数-秒数的输入控件
2016/07/01 Javascript
深入理解JavaScript中的块级作用域、私有变量与模块模式
2016/10/31 Javascript
jQuery动态追加页面数据以及事件委托详解
2017/05/06 jQuery
Swiper自定义分页器使用详解
2017/12/28 Javascript
vue3.0 CLI - 2.5 - 了解组件的三维
2018/09/14 Javascript
kafka调试中遇到Connection to node -1 could not be established. Broker may not be available.
2019/09/17 Javascript
微信用户访问小程序的登录过程详解
2019/09/20 Javascript
如何在selenium中使用js实现定位
2020/08/18 Javascript
在Python的Flask中使用WTForms表单框架的基础教程
2016/06/07 Python
python模块之time模块(实例讲解)
2017/09/13 Python
python中使用PIL制作并验证图片验证码
2018/03/15 Python
Pandas过滤dataframe中包含特定字符串的数据方法
2018/11/07 Python
浅谈Pandas Series 和 Numpy array中的相同点
2019/06/28 Python
Python3.7 读取音频根据文件名生成脚本的代码
2020/04/07 Python
总结python 三种常见的内存泄漏场景
2020/11/20 Python
HTML5 canvas基本绘图之文字渲染
2016/06/27 HTML / CSS
Helly Hansen工作服美国官方网上商店:为最恶劣的环境
2019/09/04 全球购物
数控专业毕业生求职信范文
2013/09/21 职场文书
2014年入党积极分子党课学习心得体会模板
2014/04/03 职场文书
教师思想工作总结2015
2015/05/13 职场文书
起诉书范文
2015/05/20 职场文书
世界文化遗产导游词
2019/08/07 职场文书
利用Nginx代理如何解决前端跨域问题详析
2021/04/02 Servers
Redis中有序集合的内部实现方式的详细介绍
2022/03/16 Redis