原文:https://blog.csdn.net/zhang116868/article/details/49406599

大名鼎鼎的Fiddler大家都知道,或者用过,Fiddler 开放了他的FiddlerCoreAPI  提供给开发者调用,来处理所有的http请求,功能就如Fiddler一样强大,下面我们来简单介绍一下。

程序类库官网下载地址:http://fiddler.wikidot.com/fiddlercore-api

官网上下的是exe安装文件,比较麻烦,因此笔者上传了一个安装后提取出来的库,包括.net 2.0、4.0两个运行环境版本和一个简单的实例。
下载地址:http://download.csdn.net/detail/zhang116868/9211923

接下来我们根据官方提供的SampleApp实例来进行讲解。

启动方法:

  1. //设置别名
  2. Fiddler.FiddlerApplication.SetAppDisplayName("FiddlerCoreDemoApp");
  3. //启动方式
  4. FiddlerCoreStartupFlags oFCSF = FiddlerCoreStartupFlags.Default;
  5. //定义http代理端口
  6. int iPort = 8877;
  7. //启动代理程序,开始监听http请求
  8. //端口,是否使用windows系统代理(如果为true,系统所有的http访问都会使用该代理)
  9. Fiddler.FiddlerApplication.Startup(iPort, true, false, true);
  10. // 我们还将创建一个HTTPS监听器,当FiddlerCore被伪装成HTTPS服务器有用
  11. // 而不是作为一个正常的CERN样式代理服务器。
  12. oSecureEndpoint = FiddlerApplication.CreateProxyEndpoint(iSecureEndpointPort, true, sSecureEndpointHostname);

停止方法:

  1. if (null != oSecureEndpoint) oSecureEndpoint.Dispose();
  2. Fiddler.FiddlerApplication.Shutdown();
  3. Thread.Sleep(500);

如果占用了系统代理,那么一定要记得如此退出,不然系统代理不会被释放,你将不能再打开网页。

接下来介绍拦截http请求的处理:

  1. //定义会话,每一个请求都将封装成一个会话
  2. List<Fiddler.Session> oAllSessions = new List<Fiddler.Session>();
  3. //请求出错时处理
  4. Fiddler.FiddlerApplication.BeforeReturningError += FiddlerApplication_BeforeReturningError;
  5. //在发送请求之前执行的操作
  6. Fiddler.FiddlerApplication.BeforeRequest += delegate(Fiddler.Session oS)
  7. {
  8. //请求的全路径
  9. Console.WriteLine("Before request for:\t" + oS.fullUrl);
  10. // 为了使反应篡改,必须使用缓冲模式
  11. // 被启用。这允许FiddlerCore以允许修改
  12. // 在BeforeResponse处理程序中的反应,而不是流
  13. // 响应给客户机作为响应进来。
  14. Debug.WriteLine(oS.RequestBody);
  15. oS.bBufferResponse = true;
  16. Monitor.Enter(oAllSessions);
  17. oAllSessions.Add(oS);
  18. Monitor.Exit(oAllSessions);
  19. oS["X-AutoAuth"] = "(default)";
  20. /* 如果请求是要我们的安全的端点,我们将回显应答。
  21. 注:此BeforeRequest是越来越要求我们两个主隧道代理和我们的安全的端点,
  22. 让我们来看看它的Fiddler端口连接到(pipeClient.LocalPort)客户端,以确定是否该请求
  23. 被发送到安全端点,或为了达到**安全端点被仅仅发送到主代理隧道(例如,一个CONNECT)。
  24. 因此,如果你运行演示和参观的https://本地主机:7777在浏览器中,你会看到
  25. Session list contains...
  26. 1 CONNECT http://localhost:7777
  27. 200                                         <-- CONNECT tunnel sent to the main proxy tunnel, port 8877
  28. 2 GET https://localhost:7777/
  29. 200 text/html                               <-- GET request decrypted on the main proxy tunnel, port 8877
  30. 3 GET https://localhost:7777/
  31. 200 text/html                               <-- GET request received by the secure endpoint, port 7777
  32. */
  33. //oS.utilCreateResponseAndBypassServer();
  34. //oS.oResponse.headers.SetStatus(200, "Ok");
  35. //string str = oS.GetResponseBodyAsString();
  36. //oS.utilSetResponseBody(str + "aaaaaaaaaaaaaaaaaaaaa");
  37. if ((oS.oRequest.pipeClient.LocalPort == iSecureEndpointPort) && (oS.hostname == sSecureEndpointHostname))
  38. {
  39. oS.utilCreateResponseAndBypassServer();
  40. oS.oResponse.headers.SetStatus(200, "Ok");
  41. oS.oResponse["Content-Type"] = "text/html; charset=UTF-8";
  42. oS.oResponse["Cache-Control"] = "private, max-age=0";
  43. oS.utilSetResponseBody("<html><body>Request for httpS://" + sSecureEndpointHostname + ":" + iSecureEndpointPort.ToString() + " received. Your request was:<br /><plaintext>" + oS.oRequest.headers.ToString());
  44. }
  45. //if ((oS.oRequest.pipeClient.LocalPort == 8877) && (oS.hostname == "www.baidu.com"))
  46. //{
  47. //    string url = oS.fullUrl;
  48. //    oS.utilCreateResponseAndBypassServer();
  49. //    oS.oResponse.headers.SetStatus(200, "Ok");
  50. //    oS.oResponse["Content-Type"] = "text/html; charset=UTF-8";
  51. //    oS.oResponse["Cache-Control"] = "private, max-age=0";
  52. //    oS.utilSetResponseBody("<html><body>Request for httpS://" + sSecureEndpointHostname + ":" + iSecureEndpointPort.ToString() + " received. Your request was:<br /><plaintext>" + oS.oRequest.headers.ToString());
  53. //}
  54. };
  55. /*
  56. // 下面的事件,您可以检查由Fiddler阅读每一响应缓冲区。
  57. *     请注意,这不是为绝大多数应用非常有用,因为原始缓冲区几乎是无用的;它没有解压,它包括标题和正文字节数等。
  58. //
  59. // 本次仅适用于极少数的应用程序这就需要一个原始的,未经处理的字节流获取有用
  60. Fiddler.FiddlerApplication.OnReadResponseBuffer += new EventHandler<RawReadEventArgs>(FiddlerApplication_OnReadResponseBuffer);
  61. */
  62. Fiddler.FiddlerApplication.BeforeResponse += delegate(Fiddler.Session oS) {
  63. // 取消以下两条语句解压缩/ unchunk的
  64. //HTTP响应,并随后修改任何HTTP响应,以取代
  65. //单词“微软”和“Bayden”的实例。 你必须如此设置:
  66. // set bBufferResponse = true inside the beforeREQUEST method above.
  67. //
  68. oS.utilDecodeResponse();
  69. // 内容:{3} , oS.GetResponseBodyEncoding().GetString(oS.responseBodyBytes)
  70. Console.WriteLine("{0}:HTTP {1} for {2}", oS.id, oS.responseCode, oS.fullUrl);
  71. Console.WriteLine(oS.GetResponseBodyAsString());
  72. Debug.WriteLine(oS.GetResponseBodyAsString());
  73. //bool r = oS.utilReplaceInResponse("1.欢迎使用!", "aaaaaaaaaaaaaaaaaaaaaa");
  74. //Console.WriteLine(r);
  75. };
  76. Fiddler.FiddlerApplication.AfterSessionComplete += delegate(Fiddler.Session oS)
  77. {
  78. //Console.WriteLine("Finished session:\t" + oS.fullUrl);
  79. Console.Title = ("Session list contains: " + oAllSessions.Count.ToString() + " sessions");
  80. };

作为学习,注释的代码也很重要,大家有必要拿出来运行一下,看看结果。

FiddlerCoreAPI 使用简介的更多相关文章

  1. ASP.NET Core 1.1 简介

    ASP.NET Core 1.1 于2016年11月16日发布.这个版本包括许多伟大的新功能以及许多错误修复和一般的增强.这个版本包含了多个新的中间件组件.针对Windows的WebListener服 ...

  2. MVVM模式和在WPF中的实现(一)MVVM模式简介

    MVVM模式解析和在WPF中的实现(一) MVVM模式简介 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 MVVM模式解析和在 ...

  3. Cassandra简介

    在前面的一篇文章<图形数据库Neo4J简介>中,我们介绍了一种非常流行的图形数据库Neo4J的使用方法.而在本文中,我们将对另外一种类型的NoSQL数据库——Cassandra进行简单地介 ...

  4. REST简介

    一说到REST,我想大家的第一反应就是“啊,就是那种前后台通信方式.”但是在要求详细讲述它所提出的各个约束,以及如何开始搭建REST服务时,却很少有人能够清晰地说出它到底是什么,需要遵守什么样的准则. ...

  5. Microservice架构模式简介

    在2014年,Sam Newman,Martin Fowler在ThoughtWorks的一位同事,出版了一本新书<Building Microservices>.该书描述了如何按照Mic ...

  6. const,static,extern 简介

    const,static,extern 简介 一.const与宏的区别: const简介:之前常用的字符串常量,一般是抽成宏,但是苹果不推荐我们抽成宏,推荐我们使用const常量. 执行时刻:宏是预编 ...

  7. HTTPS简介

    一.简单总结 1.HTTPS概念总结 HTTPS 就是对HTTP进行了TLS或SSL加密. 应用层的HTTP协议通过传输层的TCP协议来传输,HTTPS 在 HTTP和 TCP中间加了一层TLS/SS ...

  8. 【Machine Learning】机器学习及其基础概念简介

    机器学习及其基础概念简介 作者:白宁超 2016年12月23日21:24:51 摘要:随着机器学习和深度学习的热潮,各种图书层出不穷.然而多数是基础理论知识介绍,缺乏实现的深入理解.本系列文章是作者结 ...

  9. Cesium简介以及离线部署运行

    Cesium简介 cesium是国外一个基于JavaScript编写的使用WebGL的地图引擎,一款开源3DGIS的js库.cesium支持3D,2D,2.5D形式的地图展示,可以自行绘制图形,高亮区 ...

随机推荐

  1. wavepicking

    http://www.seismology.harvard.edu/research/wavePicking.html

  2. python3.6 ubuntu

    apt-get install python3.6-dev 安装 pip install mysqlclient 必备

  3. ZOJ 2965 Accurately Say "CocaCola"!

    Time Limit: 2 Seconds      Memory Limit: 65536 KB In a party held by CocaCola company, several stude ...

  4. 【c++基础】int转string自动补零

    前言 使用to_string函数可以将不同类型的数据转换为string类,请参考here和here.如果string的位数固定,如何进行自动补零呢?请看本文实例! 代码 确定位数,to_string ...

  5. caffe安装编译问题-ImportError: No module named caffe

    问题描述 ~/Downloads/caffe$ python Python (default, Dec , ::) [GCC ] on linux2 Type "help", &q ...

  6. xgboost 简单测试

    #coding=utf8 import pandas as pd from sklearn.model_selection import train_test_split from sklearn.f ...

  7. nginx keepalive 高可用

    https://blog.csdn.net/u012410733/article/details/57078407 在网络中机器不可避免的出现单点故障,当我们使用nginx进行反向代理的时候如果出现了 ...

  8. HDU 2111:Saving HDU(贪心)

    Saving HDU Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  9. .NET 中小心嵌套等待的 Task,它可能会耗尽你线程池的现有资源,出现类似死锁的情况

    一个简单的 Task 不会消耗多少时间,但如果你不合适地将 Task 转为同步等待,那么也可能很快耗尽线程池的所有资源,出现类似死锁的情况. 本文将以一个最简单的例子说明如何出现以及避免这样的问题. ...

  10. pycharm的安装和激活

    这里可以自定意义安装路径 32-bit是创建32位桌面快捷方式(64-bit同理) .py勾选是默认关联py文件,勾选上后所有py文件默认用pycharm打开 Download....勾选是下载安装X ...