Fiddler实践三:保存回话(save)

前言

测试某些接口的结果可以进行保存,方便其他人查看,也可以保存会话结果,对比接口文档,查看返回值是否正确

一、保存的几种方式

保存单个请求

选中某个请求,右键就能看到菜单中的Save

单个请求
单个请求
  • Selected Sessions
    • in ArchiveZIP 保存为saz文件,其实就是一个zip格式文件
    • as Text 以txt文件形式保存整个会话包括Headers/Request/Response
    • as Text (Headers only) 仅保存头部
  • Request 保存请求信息
  • Response 保存响应体,即服务器返回的数据
  • and Open as Local File 保存Response信息,并打开文件

打开保存的请求文件

  • POST类型
POST
POST
  • GET类型
GET
GET

乱码的解决方法

相信细心的你也注意到了,前面POST类型的请求,Response body是乱码,这并不是我们希望看到的。那样怎么做呢?下面贴张图,你就秒懂了。

Decode
Decode

没错,就是Response body Fiddler默认采用了GZIP压缩,只要我们勾选None,再导出就不是乱码了

Not decode
Not decode

保存所有请求

菜单File >> Save >> All Sessions,文件将以saz的形式保存下来(实际就是一个ZIP文件,也可以加密保存)

SAZ是一种以.SAZ为后缀的文件格式。SAZ是Session Archive Zip的缩写。 SAZ文件用于保存HTTP请求的信息。 在Fiddler软件使用SAZ格式用来保存和读取HTTP请求信息。

_index.htm : 一个可选文件,便于用户直接阅读。这个文件在SAZ文件被加载时不会被处理,仅仅用于手工检查。

raw文件夹:包含所有的记录了网络Sesison信息的文件。

在raw文件夹内,对于每一个网络Sesison,会有三个文件:

sessid#_c.txt:包含客户端请求

sessid#_s.txt : 包含服务器端请求

sessid#_m.txt:包含一些元数据,比如:Session标志位,socket重用信息,等等。

Save All Sessions
Save All Sessions

Repaly

1.导入请求后,可以选中某个请求,点击Repaly按钮,重新发请求

2.也可以ctrl+all全部选中后,点Repaly按钮,一次性批量请求


二、自动保存会话

前言

对APP抓包,自动保存,为后面的工作做准备

预想流程为:利用appium模拟用户触发请求–》利用fiddler抓取请求–》验证请求是否符合预期。 
Fiddler的Customize Rules功能,支持用户添加脚本(Java Script)来实现自定义功能。 

用Fiddler抓取移动端请求,百度一下了,资料很多也很全

第一步:启动fiddler,并打开Fiddler ScriptEditor

点击顶部工作栏中的“Rules–》Customize Rules…”,如下图所示:

 

第二步:ctrl+f找到OnBeforeRequest函数

在此函数后面添加以下代码:

//过滤无关请求,只关注特定请求 
        if (oSession.fullUrl.Contains("填写需要抓取的域名")) { 
            var fso;
            var file; 
            fso = new ActiveXObject("Scripting.FileSystemObject");
            //文件保存路径,可自定义 
            file = fso.OpenTextFile("填写保存TXT文件地址",8 ,true, true); 
            file.writeLine("Request url: " + oSession.url); 
            file.writeLine("Request header:" + "\n" + oSession.oRequest.headers); 
            file.writeLine("Request body: " + oSession.GetRequestBodyAsString()); 
            file.writeLine("\n"); 
            file.close(); 

        }

再来查找 OnBeforeResponse这个函数,在函数末尾添加如下代码:

        //过滤无关请求,只关注特定请求 
        if (oSession.fullUrl.Contains("填写需要抓取的域名")) { 
            oSession.utilDecodeResponse();
            //消除保存的请求可能存在乱码的情况 
            var fso; 
            var file; 
            fso = new ActiveXObject("Scripting.FileSystemObject"); 
            //文件保存路径,可自定义 
            file = fso.OpenTextFile("填写保存TXT文件地址",8 ,true, true); 
            file.writeLine("Response code: " + oSession.responseCode); 
            file.writeLine("Response body: " + oSession.GetResponseBodyAsString()); 
            file.writeLine("\n"); 
            file.close(); 

        }

    OK,重启fiddler之后就可以开始抓包了,并能自动保存。
 
 
 
链接:https://www.jianshu.com/p/442e72242adc

posted @ 2020-09-28 17:43  fanghui778  阅读(626)  评论(0)    收藏  举报