Fiddler抓取Android真机上的HTTPS包

现在的Android应用程序几乎都会和网络打交道,所以在分析一个apk的时候,如果可以抓取出其发出的数据包,将对分析程序的流程和逻辑有极大的帮助。

对于HTTP包来说,已经有很多种分析的方法了,例如用tcpdump,或者将要分析的程序跑在模拟器中然后直接在物理机上用WireShark抓包。但是现在越来越多的应用已经使用HTTPS协议来和服务器端交换数据了,这无疑给抓包分析增加了难度。

幸好有一个工具Fiddler可以用来解决这个问题。Fiddler是一个非常强大的Web调试工具,它的原理不同于WireShark。WireShark是让网卡工作在混杂模式下,截取所有网络上的数据包进行分析,而Fiddler本质上是一个HTTP/HTTPS代理服务器。


既然是代理服务器,那当然可以拿到所有的包了。

Fiddler可以从这里下载到:http://www.telerik.com/download/fiddler,如果你的Windows机上能安装.NET 4及以上的版本,尽量选择Fiddler4来安装。

好了,废话不多说了,马上动手开始抓包。这里我以Google Play为例,来演示如何操作,步骤如下:

1)请确保你的Android设备和你安装Fiddler的电脑都连接到一个WiFi AP上,两台机器在一个局域网段里,网络拓扑结构如下:


2)配置Fiddler抓取并解密HTTPS包

Fiddler默认是不抓取HTTPS包的,需要进行相应的配置。

打开Fiddler,选择“Tools->Fiddler Options...”


在弹出的对话框中选择“HTTPS”选项卡:


勾选“Capture HTTPS CONNECTs”,接着勾选“Decrypt HTTPS traffic”。同时,由于我们是通过WiFi远程连过来,所以在下面的选项框中选择“...from remote clients only”。

如果你要监听的程序访问的HTTPS站点使用的是不可信的证书,则请接着把下面的“Ignore server certificate errors”勾选上。

接着切换到"Connections"选项卡:


监听端口默认是8888,当然你可以把它设置成任何你想要的端口。请一定要勾选上“Allow remote computers to connect”。

为了减少干扰,可以去掉“Act as system proxy on startup”。

最后点“OK”退出,Fiddler就算是设置好了。

还有一点提醒大家注意,请一定记住将你本机上的防火墙关闭,笔者在这上面浪费了不少时间。

3)设置Android设备,添加上代理服务器

先查看一下安装Fiddler的电脑的IP地址是多少,在cmd里使用ipconfig命令就好了。


可以看到,笔者电脑分配到的IP地址是192.168.11.8。这就是要在Android设备上设置的代理服务器地址,至于端口嘛,就是在前面设置的监听端口,默认是8888。

好了,一切准备就绪,下面来设置Android设备上的代理服务器。

打开WiFi设置页面,选择要连接的AP,并且长按,在弹出的对话框中,选择“修改网络”。


在接下来弹出的对话框中,勾选“显示高级选项”。在接下来显示的页面中,点击“代理”,选择“手动”。

在“代理服务器主机名”和“代理服务器端口”中写上前面得到的地址和端口,最后点“保存”。


最后,连接上这个无线AP就可以了。

4)导证书到Android设备

Fiddler本质上是一个HTTPS代理服务器,其自己带的证书显然不会在Android设备的受信任证书列表里。

有些应用程序会查看服务器端的证书是否是由受信任的根证书签名的,如果不是就直接跳出。

所以,为了保险起见,我们要将Fiddler代理服务器的证书导到Android设备上。

导入的过程非常简单,打开设备自带的浏览器,在地址栏中输入代理服务器的IP和端口,例如本例中我们会输入192.169.11.8:8888,进入之后会看到一个Fiddler提供的页面:


点击页面中的“FiddlerRoot certificate”链接,接着系统会弹出对话框:


输入一个证书名称,然后直接点“确定”就好了。

一切都设置完成了,我们来抓包看看效果吧,打开Android设备上的“Google Play”,看看能拿到什么:



看到了没有,全都能拿出来,再结合其它的一些动态或静态的分析方法,破解协议将变得容易一些。

最后,不得不提这种方法的一些优点和缺点。

首先来谈优点,有以下几点:

1)手机不需要root就可以抓包;

2)可以用真机抓包,有些程序是抗动态分析的,能够判断自己运行在模拟器中。

缺点嘛,当然也有:

1)必须要用WiFi连接(这个很容易满足);

2)要抓包分析的应用程序必须自己支持代理服务器的设置。

  • 7
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: Fiddler可以通过设置代理来抓取机上https。首先需要在手机上设置代理,将代理地址设置为电脑上运行Fiddler的IP地址和端口号。然后在Fiddler中启用HTTPS抓取功能,即可抓取机上https。需要注意的是,抓取https需要安装Fiddler的根证书,否则会出现证书错误。 ### 回答2: Fiddler这一开源的网络调试工具可以帮助开发人员抓取并分析手机上HTTPS,从而更好地解决一些网络问题。首先,我们需要在PC端和手机端分别安装FiddlerFiddler代理证书。 安装Fiddler时,需要勾选“允许远程计算机连接”的选项,并确保电脑和手机在同一局域网内。另外,手机需要设定代理为PC端的IP地址和Fiddler端口号,才能获得对HTTPS的有效抓。 同时,为了能够正确地抓取HTTPS,我们还需要在手机和PC端都安装Fiddler代理证书。可以在Fiddler中的“Tools”>“Options”>“HTTPS”中找到Fiddler根证书的位置,然后将证书导入到手机中就可以了。 一旦Fiddler和代理证书都已经安装好,就可以开始进行HTTPS抓取和分析了。在Fiddler中,点击“Actions”>“Do not decrypt HTTPS traffic”,然后在手机上去触发HTTPS请求,并回到Fiddler中查看HTTPS的代理流量。在Fiddler中,无论是HTTP还是HTTPS流量都会以会话流量呈现出来,通过点击不同的会话我们可以查看流量的详细信息,括请求方法、请求头、请求体、返回状态码等信息。 此外,Fiddler还可以帮助我们解决HTTPS的安全问题。比如,可以通过配置Fiddler的TLS性能优化来提高HTTPS连接的性能,通过安装Fiddler Extension与Fiddler Script等插件来增强自动化测试和数据分析的能力,以及设置自动响应模板来快速返回特定的响应等等。 总之,Fiddler抓取手机HTTPS是一项非常有用的工作,不仅帮助我们在开发调试时更好地分析网络问题,同时也帮助我们更好地掌握安全性。而通过详细学习掌握Fiddler的使用技巧,我们可以更好地运用Fiddler去做更多更有意义的工作。 ### 回答3: Fiddler是一个常用的网络抓工具,可以用来分析HTTP和HTTPS请求。在开发移动应用过程中,我们有时需要抓取手机端的HTTPS来进行调试和分析。下面就介绍一下如何使用Fiddler抓取手机端的HTTPS。 首先,我们需要将手机设置为代理模式,使Fiddler能够拦截手机端的网络流量。具体操作方式如下: 1. 在手机的Wi-Fi设置中,找到当前连接的Wi-Fi网络,点击进入高级选项。 2. 在高级选项中,找到代理设置(Proxy),将代理设置为手动(Manual),并将代理服务器地址设置为PC端运行Fiddler的IP地址和端口号(默认端口号为8888)。 3. 打开Fiddler,在Tools -> Fiddler Options -> HTTPS选项卡中,勾选Capture HTTPS CONNECTs和Decrypt HTTPS traffic,并点击Actions -> Trust Root Certificate,在弹出的对话框中选择是(Yes),这样Fiddler会自动安装一个根证书用于解密HTTPS流量。 4. 确认Fiddler已经开始工作,然后回到手机端,访问一些使用HTTPS协议的网站,Fiddler就会自动捕获到相关的HTTPS请求和响应,并显示在Fiddler的Sessions窗口中。如果出现了证书错误的提示,需要在手机上安装Fiddler的根证书,以便于Fiddler能够成功地解密HTTPS流量。 通过Fiddler抓取手机端的HTTPS,可以帮助我们更好地了解移动应用的网络请求和响应机制,从而进行调试和分析。但需要注意的是,因为HTTPS协议的加密性,我们应该尽量避免在生产环境中使用类似于Fiddler这样的抓工具,以保证网络通信的安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值