Fiddler入门:下载、安装、配置、抓包、customize rules

本文详细介绍了Fiddler的下载、安装步骤,包括HTTPS和Connections配置,以及如何解决自动关闭问题。还涵盖了抓包技巧,如电脑、小程序和APP网络请求,以及自定义规则和脚本编写。最后强调实践操作的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、fiddler下载安装

安装包下载链接:https://www.telerik.com/download/fiddler

随便选个用途,填写邮箱,地区选择China,勾选“I accept the Fiddler End User License Agreement”,点击“DownLoad for windows”,下载。

双击FiddlerSetup.exe安装fiddler,可以选择常用的、不那么深的一个路径。

在安装路径下,双击Fiddler.exe,能打开,说明安装成功,可以给Fiddler.exe创建一个桌面快捷方式。

二、fiddler配置

双击Fiddler.exe,弹出“AppContainer Configuration”对话框,点击“cancel”就行。

Progress Telerik Fiddler Web Debugger菜单栏中,Tools——Options。

2-1.HTTPS配置

HTTPS的配置如下:

勾选Capture HTTPS CONNECTs、Decrypt HTTPS traffic、Ignore server certificate errors(unsafe)。

点击OK保存。

弹出对话框“SCARY TEXT AHEAD:Read Carefully!”,点击YES。

弹出对话框“安全警告”,询问是否安装证书,点击是。

弹出对话框“Add certificate to the Machine Root List?”,点击YES。

弹出对话框“TrustCert Success”,点击确定。

再点击一下options中的ok,以防忘记保存配置。

Decrypt HTTPS traffic中的选项说明:

from all processes : 
抓取所有的 https 程序, 包括电脑程序和手机APP。
from browsers only : 
只抓取浏览器中的https请求。
from non-browsers only : 
只抓取除了浏览器之外的所有https请求。
from remote clients only:
只抓取远程的客户端的https请求,就是只抓取手机APP上的https请求。

注意事项:

如果HTTPS请求出问题,例如,浏览器提示“您的链接不是私密链接”等,一般都是证书安装有问题,重新安装一遍证书,重复一遍HTTPS配置即可。

Options——HTTPS——Actions——Trust Root Certificate。

2-2.Connections配置

Fiddler listens on port,确保fiddler的端口为8888。

勾选Allow remote computers to connect。

弹出对话框“Enabling Remote Access”对话框,点击确定。

点击OK。

2-3.Scripting

自定义脚本语言设置,可以选择C#或者http://Jscript.NET

三、解决fiddler自动关闭

人行征信密码控件会导致fiddler经常自动停止,并提示:

在控制面板,卸载人行征信安全控件。

删除C:\Windows\Prefetch路径下PBCCR开头的.pf文件。

删除C:\Windows\SysWOW64下面的PBCCRCNew文件夹。

重新启动Fiddler.exe。

四、抓包

3-1.电脑

电脑端的网络请求,可以直接在fiddler中看到效果。

3-2.小程序

打开微信PC端,进入小程序面板,选择小程序。就可以在fiddler中看到小程序的网络请求了。

3-3.APP

一般APP都有web端主页,也有微信小程序,所以APP的网络请求可以通过web端主页看,或者通过小程序看。

如果一定要通过远程客户端的形式,抓包APP的网络请求,可参见APP抓包设置:

https://blog.csdn.net/qq_39720249/article/details/81069929

其中“三、APP抓包时的手机代理设置”写得很详细。

五、自定义规则

有时候需要把响应数据过滤保存,就需要写fiddler脚本了。

快捷键ctrl+r,或者菜单栏——Rules——Customize Rules,打开规则脚本编辑器,Fiddler ScriptEditor。

Go中,可以定位到不同方法,OnBeforeRequest、OnBeforeResponse等。

5-1.一些常用的oSession函数和方法

// 请求host
 oSession.host == "my.test.com";
 // 请求host之后的url是否包含
 oSession.url.Contains("/feed") ;
 // 获取响应内容的字符串
 var logContent = oSession.GetResponseBodyAsString(); 
 // 创建写入流
 var sw : System.IO.StreamWriter; 
if (System.IO.File.Exists(filename)){  //是否有该文件夹  
    sw = System.IO.File.AppendText(filename);   //有添加
    sw.Write(logContent);  
}  
else{  
    sw = System.IO.File.CreateText(filename);  //没有创建
    sw.Write(logContent);  
}  
sw.Close();  //关闭写入流
sw.Dispose();  //销毁写入流

 // 修改session中的显示样式
 oSession["ui-color"] = "orange";
 // 移除http头部中的MQB-X5-Referer字段
 oSession.oRequest.headers.Remove("MQB-X5-Referer");
 // 修改http头部中的Cache-Control字段
 oSession.oRequest["Cache-Control"] = "no-cache";
 // 修改host
 oSession.host = "example.domain"; 
 // 修改Origin字段
 oSession.oRequest["Origin"] = "http://domain";
 // 删除所有的cookie
 oSession.oRequest.headers.Remove("Cookie");
 // 新建cookie
 oSession.oRequest.headers.Add("Cookie", "username=cookiename;");
 // 修改Referer字段
 oSession.oRequest["Referer"] = "https://yoururl";
 
 // 获取Request中的body字符串
 var strBody=oSession.GetRequestBodyAsString();
 // 用正则表达式或者replace方法去修改string
 strBody=strBody.replace("aaaa","bbbbbb");
 // 将修改后的body,重新写回Request中
 oSession.utilSetRequestBody(strBody);
// 判断连接中是否包含字符串str
oSession.uriContains(str)
// 给连接请求添加一个字段TEST
oSession.oRequest["TEST"]="TEST NEW Request";

5-2. 定义规则保存网络请求

下面这段代码,可以将将响应数据筛选出来,存储在txt文本中。

其中判断请求url中是否包含路径是oSession.fullUrl.Contains方法,将字符串转为json的是Fiddler.WebFormats.JSON.JsonDecode(response_body)方法,获取对象中的json是response_json.JSONObject方法,打印日志是FiddlerApplication.Log.LogString(video_name)方法。

	static var video_name: String = "";
    static function OnBeforeResponse(oSession: Session) {
        if (m_Hide304s && oSession.responseCode == 304) {
            oSession["ui-hide"] = "true";
        }
		//过滤无关请求,只关注特定请求
		if (oSession.fullUrl.Contains("/burdock/weixin")) {
			//消除保存的请求可能存在乱码的情况
			oSession.utilDecodeResponse();
			var fso;
			var file;
			var response_code;
			var response_body;
			var response_json;
			response_code = oSession.responseCode;
			response_body = oSession.GetResponseBodyAsString();
			fso = new ActiveXObject("Scripting.FileSystemObject");
			response_json = Fiddler.WebFormats.JSON.JsonDecode(response_body);
			if (response_code == 200){
				if (oSession.fullUrl.Contains("user")){
					if (response_json.JSONObject["data"] == "System.Collections.ArrayList"){
						var title = response_json.JSONObject["data"][0]["user"]["nickname"];
						file = fso.OpenTextFile("D:\\视频\\" + title + ".txt",8 ,true, true);
						file.writeLine(response_body);
						file.writeLine("\n");
						file.close();
						FiddlerApplication.Log.LogString(title);
					}					
				}
				else if (oSession.fullUrl.Contains("note") && oSession.fullUrl.Contains("single_feed")){
					video_name = response_json.JSONObject["data"]["title"];
					file = fso.OpenTextFile("D:\\视频\\" + video_name + ".txt",8 ,true, true);
					file.writeLine(response_body);
					file.writeLine("\n");
					file.close();
					FiddlerApplication.Log.LogString(video_name);
				}
				else {
					file = fso.OpenTextFile("D:\\视频\\" + video_name + ".txt",8 ,true, true);
					file.writeLine(response_body);
					file.writeLine("\n");
					file.close();
					FiddlerApplication.Log.LogString(video_name);
				}
			}
		}
    }

六、总结

很全面详细的fiddler入门教程,如果觉得不错,请点赞。

更多内容可参阅fiddler官网:

 总结

如果你对此文有任何疑问,如果你也需要接口项目实战,如果你对软件测试、接口测试、自动化测试、面试经验交流感兴趣欢迎加入我们,加入方式在文章的最后面

  2023自学fiddler抓包,请一定要看完【如何1天学会fiddler抓包】的全网最详细视频教程!!_哔哩哔哩_bilibili

  总结:

 光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

如果对你有帮助的话,点个赞收个藏,给作者一个鼓励。也方便你下次能够快速查找。

如有不懂还要咨询下方小卡片,博主也希望和志同道合的测试人员一起学习进步

在适当的年龄,选择适当的岗位,尽量去发挥好自己的优势。

我的自动化测试开发之路,一路走来都离不每个阶段的计划,因为自己喜欢规划和总结,

测试开发视频教程、学习笔记领取传送门!!

### 如何下载安装 Fiddler #### 下载 Fiddler Fiddler 是一款功能强大的网络调试工具,用于监控、捕获、修改 HTTP 和 HTTPS 流量。要下载 Fiddler,请访问其官方网站 https://www.telerik.com/fiddler[^2]。在官网上选择经典版(Classic)进行下载。填写有效的电子邮件地址并同意相关协议后,点击【Download For Windows】按钮即可开始下载过程。 #### 安装步骤 运行已下载安装文件,按照向导逐步完成安装流程。以下是具体的操作指南: 1. **启动安装程序** 双击下载好的安装包以启动安装向导。 2. **遵循安装指引** 按照屏幕上的提示一步步操作,直至安装完成[^1]。 3. **配置环境** 安装完成后,首次启动 Fiddler 时可能需要设置一些基本选项,比如启用 HTTPS 解密等功能。这一步对于后续正常使用非常重要。 #### 配置信任证书 (Windows & macOS) 为了能够解密 HTTPS 请求,必须让操作系统信任 Fiddler 的根证书。以下是针对不同平台的具体方法: - 对于 **Windows 用户**:通常只需接受弹窗中的安全警告即可自动完成证书部署。 - 对于 **macOS 用户**:登录账户之后依据页面指示手动添加 CA 根证书到系统受信列表里,并确认所有权限均已授予[^3]。 至此,您已经完成了 Fiddler 的整个安装与基础配置工作! ```bash # 如果遇到无法正常抓取HTTPS流量的情况,请重新核查证书状态: certutil -addstore root fiddlertmp.cer ``` 以上命令适用于Windows PowerShell环境下更新本地计算机存储区内的可信颁发者数据源。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值