-
利用fiddlercore,修改http/https请求与响应
fiddler抓包工具,相信很多人都用过,很好用的一款抓包工具。
fiddlercore是官方提供给开发者调用的,用来处理所有的http/https请求,功能就如Fiddler一样强大,fiddlercore官方网站:https://www.telerik.com/fiddlercore
下面我们利用fiddlercore来修改浏览器的响应数据。
自动设置https证书,所有请求都返回“二十有为”
using System; using System.Collections.Generic; using System.IO; using System.Reflection; using System.Threading; using Fiddler; using System.Net.Security; using System.Security.Cryptography.X509Certificates; using System.Text; namespace Demo { class Program { static Proxy oSecureEndpoint; static string sSecureEndpointHostname = "localhost"; static int iSecureEndpointPort = 9876; static void Main(string[] args) { Console.WriteLine("Starting ..."); Fiddler.CertMaker.createRootCert(); X509Certificate2 oRootCert = Fiddler.CertMaker.GetRootCertificate(); SetMachineTrust(oRootCert); Fiddler.FiddlerApplication.oDefaultClientCertificate = oRootCert; List<Fiddler.Session> oAllSessions = new List<Fiddler.Session>(); #region AttachEventListeners Fiddler.FiddlerApplication.BeforeRequest += delegate(Fiddler.Session oS) { oS.bBufferResponse = true; HTTPRequestHeaders rHeads = oS.oRequest.headers; //获取cookie string cookie = rHeads.AllValues("cookie"); if ((oS.oRequest.pipeClient.LocalPort == iSecureEndpointPort) && (oS.hostname == sSecureEndpointHostname)) { oS.utilCreateResponseAndBypassServer(); oS.oResponse.headers.HTTPResponseStatus = "200 Ok"; oS.oResponse["Content-Type"] = "text/html; charset=UTF-8"; oS.oResponse["Cache-Control"] = "private, max-age=0"; oS.utilSetResponseBody("<html><body>show!</body></html>"); } }; Fiddler.FiddlerApplication.BeforeResponse += new Fiddler.SessionStateHandler(FiddlerApplication_BeforeResponse); Console.CancelKeyPress += new ConsoleCancelEventHandler(Console_CancelKeyPress); #endregion AttachEventListeners Fiddler.CONFIG.IgnoreServerCertErrors = true; FiddlerApplication.Prefs.SetBoolPref("fiddler.network.streaming.abortifclientaborts", false); FiddlerCoreStartupFlags oFCSF = FiddlerCoreStartupFlags.Default; int iPort = 0; Fiddler.FiddlerApplication.Startup(iPort, oFCSF); oSecureEndpoint = FiddlerApplication.CreateProxyEndpoint(iSecureEndpointPort, true, sSecureEndpointHostname); if (null != oSecureEndpoint) { WriteCommandResponse("success!"); } bool bDone = false; do { Console.WriteLine("\nEnter h or q:"); Console.Write(">"); ConsoleKeyInfo cki = Console.ReadKey(); Console.WriteLine(); switch (cki.KeyChar) { case 'q': case 'Q': bDone = true; DoQuit(); break; } } while (!bDone); } static void FiddlerApplication_BeforeResponse(Fiddler.Session oSession) { if (oSession.isHTTPS) { string hostname = oSession.hostname; int stateCode = oSession.oResponse.headers.HTTPResponseCode; string pathAndQuery = oSession.PathAndQuery; //获取服务器返回的html string body = oSession.GetResponseBodyAsString(); //修改body body = "二十有为"; oSession.utilDecodeResponse(); oSession.utilSetResponseBody(body); } else { string body = oSession.GetResponseBodyAsString(); } } private static bool SetMachineTrust(X509Certificate2 oRootCert) { try { System.Security.Cryptography.X509Certificates.X509Store certStore = new System.Security.Cryptography.X509Certificates.X509Store(StoreName.Root, StoreLocation.LocalMachine); certStore.Open(OpenFlags.ReadWrite); try { certStore.Add(oRootCert); } finally { certStore.Close(); } return true; } catch (Exception) { return false; } } static void Console_CancelKeyPress(object sender, ConsoleCancelEventArgs e) { DoQuit(); } private static void WriteCommandResponse(string s) { ConsoleColor oldColor = Console.ForegroundColor; Console.ForegroundColor = ConsoleColor.Green; Console.WriteLine(s); Console.ForegroundColor = oldColor; } private static void DoQuit() { WriteCommandResponse("Shutting down..."); if (null != oSecureEndpoint) oSecureEndpoint.Dispose(); Fiddler.FiddlerApplication.Shutdown(); Thread.Sleep(500); } } }
Demo下载地址:https://pan.baidu.com/s/1_s7ywb3O6zuMto5SDH4Jng
提取码:czun
出处:https://www.cnblogs.com/youzilong202/p/17102912.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数