Android中Fiddler的使用技巧

[TOC]

对于前端开发,Fiddler应该是比较常用的网络请求监听工具了,之前为了跨平台还想使用wireshark,但是发现相比起来不太友好,折腾过后才发现原来Fiddler也有linux和mac版本(多亏了.net开源,需要安装mono,后面会有链接,当然体验会差点),本文就介绍几个有用却被用得比较少的技巧(本文基于Fiddler V4.6);

Fiddler在客户端和服务器之间假设了一个代理,我们可以通过它对请求和响应进行各种操作,


原理
原理

1. 下载安装

win
mac/linux
linux中需要安装mono:

sudo apt-get install mono-complete
mono Fiddler.exe 

另外,也可以在mac中开启虚拟机运行windows系统然后运行Fiddler,具体可以参考 这篇文章 , 主要就是设置虚拟机网卡为 '桥接模式' 并记录下ip,然后在mac中设置网络proxies为虚拟机即可,若要抓取手机包,则将手机代理也设置为虚拟机的ip即可;

主界面
主界面

2. 插件安装

Fiddler也可以安装插件,由于安装的时候碰到点坑,这里也记录一下: 到 这里 下载插件,我下载了一个 Traffic Differ , 是个 exe 文件,双击安装并重启Fiddler( File-exit ,然后重新启动)后,选择了任意两个请求, 右键-compare(ctrl+w) ,提示我找不到 WinDiff.exe ,使用 EveryThing 搜索后发现生成的 WinDiff.exeC:\Program Files (x86)\Microsoft WebMatrix 中,这个目录不再我系统 path 环境变量下,导致找不到,添加下即可;
P.S. 插件运行后除了生成 WinDiff.exe外,还在 Fiddler2/Scripts 目录下生成了 Differ.dll,可以查看下,另外,插件是否安装也可以在 toolsTelerik Fildder OptionsExtensions 面板中查看;

3. 开启代理,实现请求中转

1. 设置Fiddler端口,允许远程连接

单击菜单栏: toolsTelerik Fildder OptionsConnections,进行如下设置,其中端口号可以自定义,不冲突即可,并允许远程连接;

options
options

2. 手机端设置Wifi代理

当然,Fiddler安装的主机要跟手机在同一个无线网络中,在手机中设置wifi代理参数,其中端口号就是Fiddler中设定的,而路由ip地址是Fiddler所在主机的网址:


手机wifi代理设置
手机wifi代理设置

至此我们就成功使用Fiddler作为手机的代理了;

3. Filters过滤器设置

主要设定好后,要单击 Actions - Run Filterset Now 来使过滤条件生效

Filter
Filter

4. Composer模拟请求

可以直接拖拽会话列表中的已有请求到本页面,修改数据后,execute执行,但是我们有另一个利器 postman,就不需要这里了吧;

5. 模拟弱网络情况

直接上图


菜单开启弱网络模拟
菜单开启弱网络模拟
代码修改网速
代码修改网速

6. 重定向资源/模拟数据

开发时候,通常客户端和服务器是两拨人马在做,经常是接口文档已出,但接口并未实现或者无数据或数据不完整,导致客户端测试时候很痛苦,需要在程序中各种判断各种假数据,使用Fiddler可以使用本地资源替换服务端的response即可;

另外,Fiddler支持多种url匹配的方式(可以从 url pattern 下拉列表中查看):

  • 字符匹配
    如输入 csdn,可以匹配 http://www.csdn.net/ 或者 http://blog.csdn.net/
  • 精确匹配
    EXACT 开头表示完全匹配,如上边的例子
    EXACT:http://blog.csdn.net
  • 正则表达式匹配
    regex: 开头,如 regex:(?insx).*.(css)$ 表示匹配所有以css结尾的请求url ;

如下图,可以指定某个请求url后,指定其要返回的数据,比如某个根据接口文档信息生成的json文件,虽然同样都是造假数据,但是一来不影响程序逻辑,不增加代码,多人协同开发时,还方便复用和重现;
P.S. 即可要勾选 Unmatched requests passthrough, 不然所有请求的返回都会被拦截的;

AutoResponder
AutoResponder

7. 其他方式修改reqeust/response

常碰到需要测试某个数据的时候,服务端又没有要求的数据,等着后台生成数据或者使用上面的方法模拟全部数据都比较麻烦,我们其实可以直接修改response内容,然后再返回给客户端的,这就是断点功能(这里以断response为例);

P.S. 修改request的话可以如下图


before request
before request

1. 菜单栏启用断点After responses

这种方式会对所有请求都进行断点


automatic_breakpoints
automatic_breakpoints

response被断点后,可以在 Inspectors - Response TextView 面板中直接修改返回的数据,也可通过 Choose Response 下拉菜单中选择预定义的模板或者 通过 find a file 来指定本地文件作为resposne,类似上面说过的重定向资源:

直接修改数据
直接修改数据

2. 命令行临时断点

菜单栏开启断点会对所有请求都做断点操作,不太方便,我们其实也可以临时对符合指定条件的请求做断点:
命令行中支持的几个断点方式如下:

// 当这些命令没有加参数时,会清空所有设置了断点的Http请求:
bpafter xxx: 中断 URL 中包含指定字符的全部 session 响应
bps xxx: 中断 HTTP 响应状态为指定字符的全部 session 响应
bpv xxx: 中断指定请求方式的全部 session 响应
bpm xxx: 中断指定请求方式的全部 session 响应,等同于bpv xxx
bpu xxx:与bpafter类似

比如输入: bpafter csdn,就会对所有请求url中含有 csdn 请求,在返回时进行断点操作;
P.S. 其他比较有用的命令行:

?text 选择所有 URL 匹配问号后的字符的全部 session
=status 选择响应状态等于给定状态的所有HTTP请求
=method 选择请求方式为指定method的请求会话,如 =get
>size 或者 <size 选择响应大小大于/小于size(单位b)的请求,如 >1k
@host  选择包含指定 host 的全部 HTTP请求
bold xxx 加粗满足指定条件的会话名,如 bold  csdn,则包含 `csdn` 的请求会被加粗显示
cls 或者 clear  清空会话列表,不过我习惯用快捷键ctrl+a ctrl+x来删除
select xxx 选择Content-Type头中包含指定字符串的响应,可用于选择文件格式,如 select image
go  跳过当前断点,跟常用工具栏上的 `go` 按钮功能一样
urlreplace www.demo.com  www.dev.demo.com  将host为 'www.demo.com'的请求替换为'www.dev.demo.com'

3. 脚本配置修改

官方文档
其实跟从菜单栏启动断点功能差不多,只不过更灵活, 通过 Rules - Customize Rules(Ctrl+R) 开启编辑器,初次运行可能会提示安装编辑器:
单击编辑器菜单 go - before OnBeforeResponse 会定位到 OnBeforeResponse 函数,在response返回给客户端前会先进入该方法,我们可以在里面进行某些设置:

if(oSession.uriContains("http://fepapi.debug.web.nd/v1/master_infos/2080998854")){
    oSession["ui-color"]="#0000ff";//设置颜色
    oSession.oResponse["newResponseHead"]="hello";//添加一个请求头
    oSession.oResponse.headers.Remove("Date");//删除请求头,测试大小写不敏感,request的类似
}

我们可以修改 OnBeforeRequest 函数,对请求头进行处理:

// 修改查询路径和条件 
if(oSession.PathAndQuery==”/v1/master_infos/2080998854”){//除主机名后面的完整部分 
    oSession[“ui-color”]=”red”;// 满足条件时显示颜色 
    oSession.PathAndQuery=”/v1/master_infos/2079941150”//修改查询路径 
}

//修改请求主机名 
if (oSession.HostnameIs(“fepapi.debug.web.nd”)) { 
    oSession.hostname=”www.baidu.com”; 
}

扩展几个小技巧:

1. 在会话列表中隐藏指定status的会话

可以参考 Rules - Hide 304s,隐藏304请求的写法,我们在 Fiddler ScriptEditor中搜索 304s,发现

// 在菜单栏中增加一个选项,也可以不用的
public static RulesOption("Hide 304s")
BindPref("fiddlerscript.rules.Hide304s")
var m_Hide304s: boolean = false;

//搜索布尔值 `m_Hide304s`
static function OnBeforeResponse(oSession: Session) {           
    if (m_Hide304s && oSession.responseCode == 304) {
        oSession["ui-hide"] = "true";
    }
}

8. 其他

部分快捷键

定位到命令行 : alt+q
快速改变会话行颜色 : ctrl+N (N为数字,0表示取消颜色,1为红色 ... 可通过 右键-mark 查看)
删除选中的会话 : ctrl+x
反选会话 : ctrl+i (这个配合命令行过滤以及ctrl+x可以让会话列表变得清爽清晰很多)

9. 参考资料

  1. 官方文档
  2. Fiddler Script 与 HTTP 断点调试
  3. 调试之Fiddler修改返回结果Response
  4. Fiddler(一)-Fiddler简介
  5. Fiddler(二)-使用Fiddler做抓包分析
  6. Fiddler(三)-Fiddler命令行和HTTP断点调试
  7. 用Fiddler模拟低速网络环境
  8. Fiddler常用命令
  9. Mac/linux下使用Fiddler-虚拟机

相关文章推荐: Charles的使用

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容

  • 原因 在现实项目中,由于开发的经常调试,接口的不稳定,和接口文档的不及时更新,我们选择做接口测试,更多的需要自己抓...
    我为峰2014阅读 3,107评论 1 5
  • Fiddler_官方网站Fiddler_官方文档Fiddler_官方视频Fiddler_官方插件1、Filddle...
    52Alice阅读 7,741评论 0 10
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,028评论 25 707
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,946评论 6 13
  • 演讲在竞选中必不可少,好的演讲不仅可以使别人更加崇拜你,信服你,也能使你获得一个好的职位 强烈的演讲热情 要使自己...
    国民小扎西阅读 96评论 2 2