search
Homephp教程php手册mitmproxy中间人攻击的神器

mitmproxy——中间人攻击的神器

 一、前言

  http proxy在web渗透上占据着非常重要的地位,这方面的工具也非常多,像burp suite, Fiddler,Charles简直每个搞web的必备神器,还有历史比较久远的paros,webscarab等,实际上每个web漏洞扫描器都有http代理的功能。

  而今天要介绍的mitmproxy代理工具,非常棒,特别是对https数据的截获,及可扩展性,bra bra……

  之所以选择这款工具,是为了做移动APP的通信分析。我们知道使用http代理的基本条件就是网络要互通,而很多情况下,公司的移动网络与办公网络是隔离的,当然你可以用网络共享(或者买个小度wifi或360wifi)的方法来解决隔离。(记得几年前做移动通信分析时就遇到了网络隔离且没有无线网卡的尴尬情况。)

  我的选择是在vps上搭建一个http代理(刚买了vps,正可着劲的折腾呢),这时候就需要命令行的工具了,于是选择了mitmproxy(其实我也用nginx搭建了代理,目前以查看通信为主,待熟练了,或许能用nginx-lua模块写个截获重写的模块,悲催的是nginx不支持https,扯远了)。

  二、mitmproxy原理

  mitmproxy就是代理,有篡改功能的代理。它支持两种模式,正向代理,与透明代理,支持http通信与https通信。

  (正向代理,反向代理,透明代理的科普可以看http://z00w00.blog.51cto.com/515114/1031287这篇文章,很容易懂)

  mitmproxy官网上也有介绍原理,这里附上好心人的翻译http://www.oschina.net/translate/how-mitmproxy-works

  对代理很了解的同学,看看下面四幅图,就能知道是咋回事了。

  1. http正向代理

  2. https正向代理

  3. http透明代理

  4. https透明代理

  三、mitmproxy安装

  接下来我要在vps上安装mitmproxy了,该工具使用python编写,现在非常多的工具都是python编写的,都有专门的python黑客培训机构了,话说不会python的程序员不是好程序员。

  python是跨平台的,因此mitmproxy也是跨平台的。

  接下来以linux(debian 7)上安装为例,其他平台非常类似(mac上安装包用homebrew就好)

  1. 首先安装python环境,了解python的可以不用看

  #python及python依赖包apt-get install build-essential python-dev python-setuptools#安装pip,很好的python包管理器,类似于aptitude,apt-getwget https://pypi.python.org/packages/source/p/pip/pip-1.4.1.tar.gzpython setup.py install

  2. 安装mitmproxy依赖包

  sudo pip install netlib pyopenssl pyasn1 urwid pil lxml flask#下面是可选(为了解码用)sudo pip install pyamf protobuf#下面是可选(为了测试用)sudo pip install nose pathod countershape

  3. 安装mitmproxy

  sudo pip install mitmproxy

  安装成功后会在生成两个工具/usr/local/bin/mitmproxy与/usr/local/bin/mitmdump

  本人是个开源工具杀手,总会遇到问题

  安装问题解决:

  如果使用pip安装时,出现pkg_resources.DistributionNotFound:(刚升级了osx Mavericks版本就出现了这个问题),可以先更新pip

  sudo easy_install --upgrade distributesudo easy_install --upgrade pip

  四、CA证书的安装

  要捕获https证书,就得解决证书认证的问题,因此需要在通信发生的客户端安装证书,并且设置为受信任的根证书颁布机构。下面介绍6种客户端的安装方法。

  当我们初次运行mitmproxy或mitmdump时,

  会在当前目录下生成 ~/.mitmproxy文件夹,其中该文件下包含4个文件,这就是我们要的证书了。

  mitmproxy-ca.pem 私钥

  mitmproxy-ca-cert.pem 非windows平台使用

  mitmproxy-ca-cert.p12 windows上使用

  mitmproxy-ca-cert.cer 与mitmproxy-ca-cert.pem相同,android上使用

  1. Firefox上安装

  preferences-Advanced-Encryption-View Certificates-Import (mitmproxy-ca-cert.pem)-trust this CA to identify web sites

  2. chrome上安装

  设置-高级设置-HTTPS/SSL-管理证书-受信任的根证书颁发机构-导入mitmproxy-ca-cert.pem

  2. osx上安装

  双击mitmproxy-ca-cert.pem - always trust

  3.windows7上安装

  双击mitmproxy-ca-cert.p12-next-next-将所有的证书放入下列存储-受信任的根证书发布机构

  4.iOS上安装

  将mitmproxy-ca-cert.pem发送到iphone邮箱里,通过浏览器访问/邮件附件

  我将证书放在了vps上以供下载

  http://tanjiti.com/crt/mitmproxy-ca-cert.pem mitmproxy iOS

  http://tanjiti.com/crt/mitmproxy-ca-cert.cer mitmproxy android

  http://tanjiti.com/crt/mitmproxy-ca-cert.p12 windows

  http://tanjiti.com/crt/PortSwigger.cer BurpSuite (burpsuite的证书,随便附上)

  5.iOS模拟器上安装

  git clone https://github.com/ADVTOOLS/ADVTrustStore.gitcd ADVTrustStore/

  DANI-LEE-2:ADVTrustStore danqingdani$ python iosCertTrustManager.py -a ~/iostools/mitmproxy-ca-cert.pem

  subject= CN = mitmproxy, O = mitmproxyImport certificate to iPhone/iPadsimulator v5.1 [y/N] yImporting to /Users/danqingdani/Library/Application Support/iPhone Simulator/5.1/Library/Keychains/TrustStore.sqlite3 Certificate added

  实际上上面的操作就是给 ~/Library/Application\ Support/iPhone\ Simulator/5.1/Library/Keychains/TrustStore.sqlite3数据库中表tsettings表中插入证书数据

  6.Android上安装

  将mitmproxy-ca-cert.cer 放到sdcard根目录下

  选择设置-安全和隐私-从存储设备安装证书

  五、工具使用

  在vps上装好了mitmproxy代理,在客户端也装好了CA证书,接下来就可以使用了。

  第一步:在vps上启动mitmproxy

  mitmproxy -b xxx.xxx.xxx(指定监听的接口) -p xxx(指定端口)

  果然我是开源工具杀手,运行时又报错了。

  运行错误问题解决:

  当运行mitmproxy报错:

  Error: mitmproxy requires a UTF console environment.

  Set your LANG enviroment variable to something like en_US.UTF-8

  你可以先运行locale查看当前的语言环境,我的vps就是POSIX环境

  root@www:/# locale

  LANG=

  LANGUAGE=

  LC_CTYPE="POSIX"

  LC_NUMERIC="POSIX"

  LC_TIME="POSIX"

  LC_COLLATE="POSIX"

  LC_MONETARY="POSIX"

  LC_MESSAGES="POSIX"

  LC_PAPER="POSIX"

  LC_NAME="POSIX"

  LC_ADDRESS="POSIX"

  LC_TELEPHONE="POSIX"

  LC_MEASUREMENT="POSIX"

  LC_IDENTIFICATION="POSIX"

  LC_ALL=

  现在我们需要的是把其修改为en_US.UTF-8

  方法参考http://jrs-s.net/2010/11/18/setting-locale-to-utf-8-in-debian/

  vim /etc/default/localeLANG=en_US.UTF-8. locale-gen#编辑/etc/profile,与/etc/bash.bashrc,增加 export LANG=en_US.UTF-8echo "export LANG=en_US.UTF-8" >/etc/profileecho "export LANG=en_US.UTF-8" >/etc/bash.bashrc source /etc/profilesource /etc/bash.bashrc

  现在再运行locale,可以看到语言修改过来了

  root@www:/# locale

  LANG=en_US.UTF-8

  LANGUAGE=

  LC_CTYPE="en_US.UTF-8"

  LC_NUMERIC="en_US.UTF-8"

  LC_TIME="en_US.UTF-8"

  LC_COLLATE="en_US.UTF-8"

  LC_MONETARY="en_US.UTF-8"

  LC_MESSAGES="en_US.UTF-8"

  LC_PAPER="en_US.UTF-8"

  LC_NAME="en_US.UTF-8"

  LC_ADDRESS="en_US.UTF-8"

  LC_TELEPHONE="en_US.UTF-8"

  LC_MEASUREMENT="en_US.UTF-8"

  LC_IDENTIFICATION="en_US.UTF-8"

  LC_ALL=

  然后就可以正常的运行了!

  第二步:在手机或PC或浏览器上选择使用该http代理

  第三步:使用客户端访问,现在就可以操作通信数据了

  六、常见操作

  1. mitmproxy

  就介绍最常用到的修改请求,并回放请求的方法吧

  (1)方向键定位请求

  (2)当黄色箭头>>定位到指定请求时,按回车enter进入请求中

  (3)按e进入编辑状态,然后按对应的蓝色字体来选择修改的部分

  可以修改query,查询字符串;path,路径;url ;header 请求头;form 表单;raw body 请求正文;method 请求方法。

  (4)a 增加一行,tab键切换编辑字段,回车enter开始编辑,esc保存,q返回上一级

  (5)修改完后,按r就可以重放请求,然后查看修改结果了

  2. mitmdump

  别忘了,mitmproxy还有个内向的双胞胎叫mitmdump(很像tcpdump),它是不交互版的mitmproxy。可以非实时的处理通信包。

  我们可以在mitmproxy中按w,将通信数据保存到指定文件中后,然后用mitmdump来操作。接下来简单介绍一个例子,从mitmproxy中捕获到的数据包中,筛选出来自微博的数据包,然后重放这个数据包(其实也可以修改后再重放)

  -n 表示不启用代理, -r表示从文件中读取数据包, -w表示将数据包存储到文件中,-c表示重放客户端请求包

  mitmdump -nr all.data -w weibo.data "~u weibo"

  mitmdump -nc weibo.data[replay] POST http://api.weibo.cn/2/client/addlog_batch?s=2edc0cfa7&gsid=4ubed3V0QehBa8KoNp4AA75J&c=android&wm=20005_0002&ua=Xiaomi-MI+2S__weibo__4.0.1__android__android4.1.1&oldwm=9975_0001&from=1040195010&skin=default&i=8764056d2&isgzip=&lang=zh_CN

  3. mitmproxy API

  开源精神最赞的是,可以像小时候玩积木一样,用大牛们提供的各种精巧工具,搭建自己合适的武器。

  mitmproxy提供了libmproxy以供调用扩展。

  我们可以查看一下libmproxy的详细说明,了解主要的API接口调用

  pydoc libmproxy

  官网给了一个自己编写脚本,来操纵数据包的例子,很简单,人人都能看懂

  如下所示,就是在响应包中增加一个自定义头

  def response(context, flow): flow.response.headers["newheader"] = ["foo"]

  我们可以在mitmdump 中使用这个脚本

  -s表示从读取自定义脚本来处理数据包

  mitmdump -ns examples/add_header.py -r infile -w outfile

  好了,就介绍到这了。

  七、希望交流

  我在运行mitmdump重放http响应功能时候

  mitmdump -S outfile

  卡死了,到目前还没有找到原因,希望知道的大牛告之,万分感谢

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
如何在 iPhone 和 Android 上关闭蓝色警报如何在 iPhone 和 Android 上关闭蓝色警报Feb 29, 2024 pm 10:10 PM

根据美国司法部的解释,蓝色警报旨在提供关于可能对执法人员构成直接和紧急威胁的个人的重要信息。这种警报的目的是及时通知公众,并让他们了解与这些罪犯相关的潜在危险。通过这种主动的方式,蓝色警报有助于增强社区的安全意识,促使人们采取必要的预防措施以保护自己和周围的人。这种警报系统的建立旨在提高对潜在威胁的警觉性,并加强执法机构与公众之间的沟通,以共尽管这些紧急通知对我们社会至关重要,但有时可能会对日常生活造成干扰,尤其是在午夜或重要活动时收到通知时。为了确保安全,我们建议您保持这些通知功能开启,但如果

在Android中实现轮询的方法是什么?在Android中实现轮询的方法是什么?Sep 21, 2023 pm 08:33 PM

Android中的轮询是一项关键技术,它允许应用程序定期从服务器或数据源检索和更新信息。通过实施轮询,开发人员可以确保实时数据同步并向用户提供最新的内容。它涉及定期向服务器或数据源发送请求并获取最新信息。Android提供了定时器、线程、后台服务等多种机制来高效地完成轮询。这使开发人员能够设计与远程数据源保持同步的响应式动态应用程序。本文探讨了如何在Android中实现轮询。它涵盖了实现此功能所涉及的关键注意事项和步骤。轮询定期检查更新并从服务器或源检索数据的过程在Android中称为轮询。通过

如何在Android中实现按下返回键再次退出的功能?如何在Android中实现按下返回键再次退出的功能?Aug 30, 2023 am 08:05 AM

为了提升用户体验并防止数据或进度丢失,Android应用程序开发者必须避免意外退出。他们可以通过加入“再次按返回退出”功能来实现这一点,该功能要求用户在特定时间内连续按两次返回按钮才能退出应用程序。这种实现显著提升了用户参与度和满意度,确保他们不会意外丢失任何重要信息Thisguideexaminesthepracticalstepstoadd"PressBackAgaintoExit"capabilityinAndroid.Itpresentsasystematicguid

Android逆向中smali复杂类实例分析Android逆向中smali复杂类实例分析May 12, 2023 pm 04:22 PM

1.java复杂类如果有什么地方不懂,请看:JAVA总纲或者构造方法这里贴代码,很简单没有难度。2.smali代码我们要把java代码转为smali代码,可以参考java转smali我们还是分模块来看。2.1第一个模块——信息模块这个模块就是基本信息,说明了类名等,知道就好对分析帮助不大。2.2第二个模块——构造方法我们来一句一句解析,如果有之前解析重复的地方就不再重复了。但是会提供链接。.methodpublicconstructor(Ljava/lang/String;I)V这一句话分为.m

如何在2023年将 WhatsApp 从安卓迁移到 iPhone 15?如何在2023年将 WhatsApp 从安卓迁移到 iPhone 15?Sep 22, 2023 pm 02:37 PM

如何将WhatsApp聊天从Android转移到iPhone?你已经拿到了新的iPhone15,并且你正在从Android跳跃?如果是这种情况,您可能还对将WhatsApp从Android转移到iPhone感到好奇。但是,老实说,这有点棘手,因为Android和iPhone的操作系统不兼容。但不要失去希望。这不是什么不可能完成的任务。让我们在本文中讨论几种将WhatsApp从Android转移到iPhone15的方法。因此,坚持到最后以彻底学习解决方案。如何在不删除数据的情况下将WhatsApp

同样基于linux为什么安卓效率低同样基于linux为什么安卓效率低Mar 15, 2023 pm 07:16 PM

原因:1、安卓系统上设置了一个JAVA虚拟机来支持Java应用程序的运行,而这种虚拟机对硬件的消耗是非常大的;2、手机生产厂商对安卓系统的定制与开发,增加了安卓系统的负担,拖慢其运行速度影响其流畅性;3、应用软件太臃肿,同质化严重,在一定程度上拖慢安卓手机的运行速度。

Android中动态导出dex文件的方法是什么Android中动态导出dex文件的方法是什么May 30, 2023 pm 04:52 PM

1.启动ida端口监听1.1启动Android_server服务1.2端口转发1.3软件进入调试模式2.ida下断2.1attach附加进程2.2断三项2.3选择进程2.4打开Modules搜索artPS:小知识Android4.4版本之前系统函数在libdvm.soAndroid5.0之后系统函数在libart.so2.5打开Openmemory()函数在libart.so中搜索Openmemory函数并且跟进去。PS:小知识一般来说,系统dex都会在这个函数中进行加载,但是会出现一个问题,后

Android APP测试流程和常见问题是什么Android APP测试流程和常见问题是什么May 13, 2023 pm 09:58 PM

1.自动化测试自动化测试主要包括几个部分,UI功能的自动化测试、接口的自动化测试、其他专项的自动化测试。1.1UI功能自动化测试UI功能的自动化测试,也就是大家常说的自动化测试,主要是基于UI界面进行的自动化测试,通过脚本实现UI功能的点击,替代人工进行自动化测试。这个测试的优势在于对高度重复的界面特性功能测试的测试人力进行有效的释放,利用脚本的执行,实现功能的快速高效回归。但这种测试的不足之处也是显而易见的,主要包括维护成本高,易发生误判,兼容性不足等。因为是基于界面操作,界面的稳定程度便成了

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

EditPlus Chinese cracked version

EditPlus Chinese cracked version

Small size, syntax highlighting, does not support code prompt function

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft