1 关于Fiddler
Fiddler
是一个HTTP/HTTPS
调试抓包工具;
- 针对我们测试人员来说,数据抓包是一个基本技能,尤其像接口测试,这就用的很频繁了;
- 我们除了进行数据抓包,平常用的最多还有实现伪造数据请求,或者伪造服务器的响应,做一些性能或者弱网测试等等。
2 Fiddler安装
- Fiddler下载官网;
data:image/s3,"s3://crabby-images/25612/256128dbba4db65f5d2585593f12518998d209c4" alt=""
- 填写相关信息,点击下载即可:
data:image/s3,"s3://crabby-images/55d61/55d61360fc3f9d65b50cd44694c15e025862b8bf" alt=""
- 还有一种安装方式是网上下载第三方的,然后解压直接使用的那种,这个有很多,可自行搜索即可;
- 我这里使用了第二种方法,直接解压使用的:
data:image/s3,"s3://crabby-images/3b22f/3b22f797d63dc279f0cd6f06f6bb66418eb9fdfe" alt=""
- 打开后主界面如下:
data:image/s3,"s3://crabby-images/73d6e/73d6e6a89b1f569c034a96be2b823d28021000f4" alt=""
3 Fiddler信息查看
3.1 查看请求信息
- 我们以抓取一条数据看下(以禅道登陆界面为例),输入用户名和密码登陆:
data:image/s3,"s3://crabby-images/2167b/2167bf6c7272766727ce181d3c5a0ecc320fbb18" alt=""
- 选择左边的一个接口,点击
fiddler
界面右侧的Inspectors
(检查器),可以看到这个接口详细请求信息;
- 其中
Raw
可以看到完整的信息: data:image/s3,"s3://crabby-images/8e5e0/8e5e024137e0ea2c9e8319acf505e2268c64a9d7" alt=""
- 比如请求的完整信息如下:
python
复制代码
POST http://localhost/zentao/user-login.html HTTP/1.1
Host: localhost
Connection: keep-alive
Content-Length: 137
sec-ch-ua: "Google Chrome";v="119", "Chromium";v="119", "Not?A_Brand";v="24"
Accept: application/json, text/javascript, */*; q=0.01
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
X-Requested-With: XMLHttpRequest
sec-ch-ua-mobile: ?0
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36
sec-ch-ua-platform: "Windows"
Origin: http://localhost
Sec-Fetch-Site: same-origin
Sec-Fetch-Mode: cors
Sec-Fetch-Dest: empty
Referer: http://localhost/zentao/user-login.html
Accept-Encoding: gzip, deflate, br
Accept-Language: zh-CN,zh;q=0.9
Cookie: lang=zh-cn; device=desktop; theme=default; goback=%7B%22program%22%3A%22http%3A%5C%2F%5C%2Flocalhost%5C%2Fzentao%5C%2Fprogram-browse.html%22%2C%22project%22%3A%22http%3A%5C%2F%5C%2Flocalhost%5C%2Fzentao%5C%2Fproject-browse.html%22%7D; zentaosid=c9e468e9ebac0b891a6914fe821ae404; windowWidth=1920; windowHeight=845; Pycharm-cc94626e=5b54e6c4-0588-4cb7-97e0-43c407bab33b
account=admin&password=450286615fad1080cfd37f5adeb1bde3&passwordStrength=1&referer=%2Fzentao%2F&verifyRand=651347427&keepLogin=0&captcha=
字段 |
说明 |
POST |
接口请求方式 |
http://localhost/zentao/user-login.html |
请求的接口地址信息 |
Content-Type |
请求的接口类型 |
account |
body 内容,用户名 |
password |
body 内容,密码 |
3.2 查看响应信息
- 请求信息的最下边栏目就是请求的响应信息,如下:
data:image/s3,"s3://crabby-images/ea7db/ea7db649c7998e56d8949eff40356c60b487ad40" alt=""
- 从图中可以看到请求返回的内容如下,表示请求是ok的:
python
复制代码
{"result":"success","locate":"/zentao/"}
3.3 查看会话信息统计
- 点击
Statistics
,可以看到一些会话信息的统计表: data:image/s3,"s3://crabby-images/ece51/ece513f42f40fd828d06acc50897495f323e24c9" alt=""
- 统计信息部分内容如下:
python
复制代码
请求计数: 1
发送字节: 1,264 (标头:1,126; 正文:138)
接收字节: 968 (标头:928; 正文:40)
ACTUAL PERFORMANCE
--------------
ClientConnected: 13:23:36.622
ClientBeginRequest: 13:23:36.796
GotRequestHeaders: 13:23:36.796
ClientDoneRequest: 13:23:36.797
Determine Gateway: 0ms
DNS Lookup: 0ms
TCP/IP Connect: 0ms
HTTPS Handshake: 0ms
ServerConnected: 13:23:36.635
FiddlerBeginRequest: 13:23:36.797
ServerGotRequest: 13:23:36.797
ServerBeginResponse: 13:23:37.114
GotResponseHeaders: 13:23:37.114
ServerDoneResponse: 13:23:37.114
ClientBeginResponse: 13:23:37.114
ClientDoneResponse: 13:23:37.114
Overall Elapsed: 0:00:00.317
RESPONSE BYTES (by Content-Type)
--------------
~headers~: 928
text/html: 40
ESTIMATED WORLDWIDE PERFORMANCE
--------------
- 统计信息的图标显示:
data:image/s3,"s3://crabby-images/b5e57/b5e57fc49ab35b0554757e081d5ee67651a34504" alt=""
4 Fiddler暂停抓包
- 启动
Fiddler
后,抓包是不停止的,只要访问网络就有数据显示并被记录;
- 如果想对一些数据抓包并分析,这里可以设置暂停抓包;
- 暂停的按钮在界面的左下角
Capturing
(抓包中),点击一下显示空白,表示暂停抓包:
data:image/s3,"s3://crabby-images/1bd31/1bd3159eeccaff922f21d69f0f2f880cc19a49d1" alt=""
5 Fiddler清除抓包数据
- 如果想清除已经抓到的数据包,直接点击界面左上角的
×
,移除所有数据即可: data:image/s3,"s3://crabby-images/c3564/c3564be78c11d3e9ac760dd61431bc9e3603b05e" alt=""
6 Fiddler设置Filters过滤
- 点击
Filters
(过滤器),进入过滤设置界面:
data:image/s3,"s3://crabby-images/2936e/2936ec3b950e90449ec43df3016be52d3294beac" alt=""
6.1 关于Actions
- 界面的上的
Actions
表示操作: data:image/s3,"s3://crabby-images/b48a2/b48a2792002ffe2a62b48ce642e360c832201e60" alt=""
- 选项说明:
data:image/s3,"s3://crabby-images/eec8f/eec8fc619d50c29bfccdb9cf50747e3e2a48f40d" alt=""
选项 |
说明 |
Run Filterset now |
立即运行过滤操作 |
Load Filterset |
加载本地过滤配置文件 |
Save Filterset |
保存过滤条件到本地文件 |
6.2 关于Use Filters
Use Filters
表示使用过滤操作;
- 勾选了这个按钮,设置的过滤器才会生效。
data:image/s3,"s3://crabby-images/004a5/004a50d9e012ac405c46613a491608f0077b8a2d" alt=""
6.3 关于Hosts
Hosts
表示使用主机名完成过滤; data:image/s3,"s3://crabby-images/c67b7/c67b7146b230feb8cd20d5d5df54434ef507d590" alt=""
- 其中参数说明如下:
参数 |
说明 |
No Zone Filter |
不区分内网和外网 |
Show only Intranet Hosts |
使用内网 |
Show only Internet Hosts |
使用外网 |
No Host Filter |
不使用主机名 |
Hide the following Hosts |
隐藏下边的主机名请求 |
Show only the following Hosts |
显示下边的主机名请求 |
Flag the following Hosts |
标志输入的主机名请求 |
6.4 关于Client Process
Client Process
表示通过客户端进程的方式完成过滤; data:image/s3,"s3://crabby-images/19dd6/19dd6f40177f7cc73d7ffea8e24d2690f631b16a" alt=""
Request Headers
请求标头: data:image/s3,"s3://crabby-images/e1bc5/e1bc5f2296b519c11b0b175bd0c44f69b13d1990" alt=""
6.6 Response Status Code
Response Status Code
通过响应状态码完成过滤; data:image/s3,"s3://crabby-images/15a2d/15a2d8f88bc845f3d423dee33b076ffd26be78bd" alt=""
6.7 Response Type and Size
Response Type and Size
通过响应类型和大小完成过滤; data:image/s3,"s3://crabby-images/4ad46/4ad46c9f81f8ed81803456aee0cb2a1156254fe5" alt=""
Response Headers
是通过响应头进行过滤设置: data:image/s3,"s3://crabby-images/b00a6/b00a63479aec21b1094b04bd222899fa4996bd99" alt=""
7 Https抓包设置
- 有时候只能抓包
http
包数据,但是https
数据包没有被抓到,这是因为没有对https
抓包进行设置;
https
实际就是http
封装了一层SSL
协议,实现传输过程中的数据加密处理;
- 所以需要
Fiddler
的证书认证;
7.1 证书设置
- 点击
Tool-Options(工具-选项)
: data:image/s3,"s3://crabby-images/3cf81/3cf81fb344efdece9e3c1a2db6288bfce716672b" alt=""
- 点击
HTTPS
: data:image/s3,"s3://crabby-images/31386/31386b0bfdf485e6ddd9e969b336a64f364d7d0f" alt=""
- 点击
Actions(操作)
,点击【将根证书导出到桌面】:
关闭工具。
7.2 导入证书
- 打开浏览器,比如
Chrome
,输入chrome://settings/
: data:image/s3,"s3://crabby-images/fc87a/fc87ac4e21a36676125df4ad984172f3158c77f7" alt=""
- 点击【隐私安全-安全】:
data:image/s3,"s3://crabby-images/60cd9/60cd942dc463bba906a4d7ee375863f3bfe1962f" alt=""
- 点击【管理证书】:
data:image/s3,"s3://crabby-images/df609/df609a4119468e97f3c25630480d0e89e72becea" alt=""
- 如图点击【导入】,导入之前导出的证书即可:
data:image/s3,"s3://crabby-images/96b56/96b560bd28830fba3ccf029b32c9688e0b7efdce" alt=""
8 Fiddler实现弱网测试
8.1 弱网环境设置
Fiddler
可通过延迟发送数据或者接收数据来源限制网络下载速度和上传速度,从而实现弱网测试;
- 弱网测试的环境设置如下;
- 主界面点击如下操作,勾选后发现网速变慢了:
data:image/s3,"s3://crabby-images/bc155/bc1551dc1441d92eedba0a5bf7259a8507c58d2d" alt=""
8.2 实现原理
python
复制代码
if (m_SimulateModem) {
// Delay sends by 300ms per KB uploaded.
oSession["request-trickle-delay"] = "300";
// Delay receives by 150ms per KB downloaded.
oSession["response-trickle-delay"] = "150";
}
- 表示如果
m_SimulateModem
设置为true
,则进入以上语句进行设置延迟, 其中request-trickle-delay
表示上传速度,response-trickle-delay
表示下载速度。
9 Fiddler设置断点
- 设置断点的目的是为了跳过前端的数据校验,通过设置断点实现数据的篡改,直接校验后端数据;
9.1 设置方式
- 断点设置方式有两种,在请求前设置 或 在响应后设置;
- 请求前设置(
Before Request
)表示数据不会先发送到服务器,而是先完成数据篡改,然后将篡改的数据发送服务器;
- 请求后设置(
After Request
)表示一个响应由多个http资源组成,多个http资源之间存在相互关联,设置后,可完成发送一个请求后所产生的多个响应的每个资源的响应获取分析。
9.2 设置示例
- 我们以禅道为例,比如登陆接口数据;
- 我们先看下请求前设置,点击【规则-自动断点-之前请求】:
data:image/s3,"s3://crabby-images/fc310/fc31047ba01fad25d88e4f76ed36ce0c34a1b263" alt=""
- 在未设置断点前,接口的数据是不能修改的,点击右边的数据是不能进行编辑的:
data:image/s3,"s3://crabby-images/cb217/cb2173711f501243ec7d4104ea710a3e4b5f074c" alt=""
- 我们设置后,就可以对右边的数据进行编辑,编辑后点击【运行到完成】:
data:image/s3,"s3://crabby-images/cdf5a/cdf5a8191b4c29582a3d076f54b5daef5371fded" alt=""
10 自动响应设置
AutoResponder
可以实现自动响应;
- 通过设置自动响应可完成部分数据篡改;
- 启用规则,第一行输入网址,第二行输入重定向操作,保存即可:
python
复制代码
EXACT:http://localhost/zentao/user-login.html
502_Unreachable.dat
python
复制代码
Fiddler: HTTP/502 unreachable server.