C# 使用Fiddler API 抓取 Android App 数据

  通过这两天的查阅资料,发现百度上对于Fiddler API 稍微高级一点的用法比较少,其中主要的教程是偏向于对Fiddler软件的使用方法,碰巧最近在做头脑王者相关的辅助,因此分享下 基于C# 对Fiddler 进行二次开发的学习经验。这里主要通过调用Fiddler提供的API 对网络流量的抓取。

一、环境搭建

1.首先去fiddler官网下载相应的API和开发文档

2.在项目中引用所有dll,反正也没多少

FiddlerCore4.dll、
CertMaker.dll、
BCMakeCert.dll、
BasicFormatsForCore.dll

 

二、关键代码

1.准备需要的变量

1         public int iSecureEndpointPort = 7777;
2         public string sSecureEndpointHostname = "localhost";
3         public int startPort = 8877;
4         public bool isIgnoreCertError = false;
5         public Proxy oSecureEndpoint; 
6       //设置fiddler的启动标识 需要允许远程计算机连接和对https的解密
7       public FiddlerCoreStartupFlags oFCSF = FiddlerCoreStartupFlags.AllowRemoteClients | FiddlerCoreStartupFlags.DecryptSSL;

 

2.添加Fiddler的启动和关闭方法

 1 public void Start(int port)
 2         {
 3             if (FiddlerApplication.IsStarted())
 4                 {
 5                     Shutdown();
 6                     FiddlerApplication.BeforeResponse -= FiddlerApplication_BeforeResponse;
 7                 }
 8             Fiddler.CONFIG.IgnoreServerCertErrors = isIgnoreCertError;
 9             this.startPort = port;
10             FiddlerApplication.Startup(startPort, oFCSF);//启动侦听
11             //创建一个https侦听器,用于伪装成https服务器
12             FiddlerApplication.Prefs.SetBoolPref("fiddler.network.streaming.abortifclientaborts", true);
13             Fiddler.CertMaker.trustRootCert();
14             FiddlerApplication.BeforeResponse += FiddlerApplication_BeforeResponse;//注册事件,用于捕获网络流量
15             oSecureEndpoint = FiddlerApplication.CreateProxyEndpoint(iSecureEndpointPort, true, sSecureEndpointHostname);
16     }
17         public void Shutdown()
18         {
19             if (null != oSecureEndpoint) oSecureEndpoint.Dispose();
20             Fiddler.FiddlerApplication.Shutdown();
21             System.Threading.Thread.Sleep(500);
22             isStart = false;
23 
24         }

 

3.捕获并处理数据

1  private void FiddlerApplication_BeforeResponse(Session oSession)
2         {
3  //oSession.url中包括响应的url 可以根url筛选自己要捕获的内容
4 
5   //oSession提供了uriContains的方法可以直接判断url 
6 //oSessionGetResponseBodyAsString方法可以直接读取响应内容
7 
8         }

 

值得注意的是抓取手机包时一般需要https证书,在服务运行后可以在手机浏览器 输入计算机IP+端口8877 (如我的:192.168.1.111:8877)打开后点击下载根证书然后在手机中安装(不能直接打开证书文件  小米安装证书是在设置--更多设置--系统安全--从SD卡安装,安装后能手机浏览器打开百度能正常显示即可)



posted @ 2018-04-12 21:18  I听音乐的猿  阅读(944)  评论(0编辑  收藏  举报