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卡安装,安装后能手机浏览器打开百度能正常显示即可)