Python进阶(三十五)-Fiddler命令行和HTTP断点调试

一. Fiddler内置命令

  上一节(使用Fiddler进行抓包分析)中,介绍到,在web session(与我们通常所说的session不是同一个概念,这里的每条HTTP请求都称为一个session)。界面中能够看到Fiddler抓取的全部HTTP请求.而为了更加方便的管理全部的session, Fiddler提供了一系列内置的函数用于筛选和操作这些session(习惯命令行操作Linux的童鞋应该能够感受到这会有多么方便).输入命令的位置在web session管理面板的下方(通过快捷键alt+q能够focus到命令行).

  Fiddler内置的命令有例如以下几种:

1. select命令

  选择全部对应类型(指content-type)为指定类型的HTTP请求,如选择图片。使用命令select image.而select css则能够选择全部对应类型为css的请求。select html则选择全部响应为HTML的请求(怎么样,是不是跟SQL语句非常像?)。

如图是运行select image之后的结果:

2. allbut命令

  allbut命令用于选择全部响应类型不是给定类型的HTTP请求。如allbut image用于选择全部对应类型不是图片的session(HTTP请求),该命令另一个别名keeponly.须要注意的是。keeponly和allbut命令是将不是该类型的session删除。留下的都是该类型的响应。因此,如果你运行allbut xxxx(不存在的类型),实际上相似与运行cls命令(删除全部的session, ctrl+x快捷键也是这个作用)。

3. ?

text命令

  选择全部 URL 匹配问号后的字符的全部 session。

4. >size 和

5. =status命令

  选择响应状态等于给定状态的全部HTTP请求。

  比如,选择全部状态为200的HTTP请求:=200

6. @host命令

  选择包括指定 HOST 的全部 HTTP请求。

  比如:@csdn.NET选择全部host包括csdn.Net的请求

7. Bpafter。 Bps, bpv, bpm, bpu

  这几个命令主要用于批量设置断点

  • Bpafter xxx: 中断 URL 包括指定字符的全部 session 响应
  • Bps xxx: 中断 HTTP 响应状态为指定字符的全部 session 响应。

  • Bpv xxx: 中断指定请求方式的全部 session 响应
  • Bpm xxx: 中断指定请求方式的全部 session 响应。等同于bpv xxx
  • Bpu xxx:与bpafter相似。

  当这些命令没有加參数时,会清空全部设置了断点的HTTP请求。

  很多其它的其它命令能够參考Fiddler官网手冊。

二.使用Fiddler进行HTTP断点调试

  这是Fiddler又一强大和有用的工具之中的一个。通过设置断点,Fiddler能够做到:

  • 改动HTTP请求头信息。

    比如改动请求头的UA, Cookie, Referer 信息,通过“伪造”对应信息达到达到对应的目的(调试,模拟用户真实请求等)。

  • 构造请求数据,突破表单的限制,任意提交数据。

    避免页面js和表单限制影响相关调试。

  • 拦截响应数据,改动响应实体。

      为什么以上方法是重要的?如果js前端程序猿和server程序猿是分工合作的。js程序猿想要调试Ajax请求的功能,这样便不必等待server端程序猿开发好全部接口之后再開始开发js端的ajax请求功能,由于通过“模拟”真实的server端的响应,便能够保证功能的正确性,而server端开发程序猿,仅仅要保证终于的响应是符合规定的就可以。

    这大大简化了程序开发的效率,当然也减少了不同业务线程序猿联调的难度。

      有两种方法设置断点:

  • 1.fiddler菜单条->rules->automatic Breakpoints->选择断点方式,这样的方式下设定的断点会对之后的全部HTTP请求有效。 有两个断点位置:

  • a. before response。也就是发送请求之后,可是Fiddler代理中转之前,这时能够改动请求的数据。

  • b.after response。也就是server响应之后,可是在Fiddler将响应中转给client之前。这时能够改动响应的结果。

  • 2.命令行下输入。Bpafter xxx或者bpv,bpu,bpm等设置断点。

    这样的断点仅仅针对特定类型的请求。

  我们以本地的web项目为例,演示怎样简单的设置HTTP断点:

  1.首先设置Firefox的代理,使之能够抓取全部的HTTP请求(localhost的请求,也能够在filter中设置仅仅抓取intranet请求),设置例如以下图所看到的:



- 这时用web打开本地的项目。

页面的内容为:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc3VuaHVhcWlhbmcx/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="这里写图片描写叙述" title="">

- 设置响应后断点(after response breakpoint),能够通过命令行设置:bpafter localhost。键入回车之后。web再次訪问文件。通过Fiddler的web session界面能够看到。请求已经被挂起来了,而web浏览器也一直处于载入的状态。观察右側的inspector面板下,也出现了新的东西:



  这时我们就能够改动响应的信息了。

改动过程为:

  切换到textView子面板,选择须要改动的部分。然后点击 “run to complete“,便可回送改动后的响应。如果我们改动后的内容例如以下:



  点击运行后。打开刚刚的web界面。

能够看到的页面的变化。



  可见。页面的响应已经有了对应的变化。这就是响应后断点。

当然实际应用中。断点的设置和响应的改动会比这复杂的多,这里仅仅是主要的演示样例。

  终止断点的方式有:

  • 在inspector界面点击“run complete“即会终止本次HTTP请求的断点。
  • 输入Go命令。也会使得当前的请求跳过断点。
  • 在rules->auto breakpoint中disabled断点就可以。

    总之。Fiddler的断点功能非常强大,关于它的进一步学习和应用,须要一个不断积累和摸索的过程。


Python进阶(三十五)-Fiddler命令行和HTTP断点调试的更多相关文章

  1. 【HTTP】Fiddler(三)- Fiddler命令行和HTTP断点调试

    一. Fiddler内置命令. 上一节(使用Fiddler进行抓包分析)中,介绍到,在web session(与我们通常所说的session不是同一个概念,这里的每条HTTP请求都成为一个sessio ...

  2. Fiddler命令行和HTTP断点调试

    fiddler设置断点: fiddler->rules->automatic Breakpoints->选择断点方式,这种方式下设定的断点会对之后的所有HTTP请求有效. 有两个断点 ...

  3. 孤荷凌寒自学python第三十五天python的文件操作之针对文件操作的os模块的相关内容

     孤荷凌寒自学python第三十五天python的文件操作之针对文件操作的os模块的相关内容 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 一.打开文件后,要务必记得关闭,所以一般的写法应当 ...

  4. Java进阶(三十五)java int与integer的区别

    Java进阶(三十五)java int与Integer的区别 前言 int与Integer的区别从大的方面来说就是基本数据类型与其包装类的区别: int 是基本类型,直接存数值,而Integer是对象 ...

  5. Appium+python自动化(三十五)- 命令启动appium之 appium服务命令行参数(超详解)

    简介 前边介绍的都是通过按钮点击启动按钮来启动appium服务,有的小伙伴或者童鞋们乍一听可能不信,或者会问如何通过命令行启动appium服务呢?且听宏哥一一道来. 一睹为快 其实相当的简单,不看不知 ...

  6. 网站开发进阶(三十五)JSP页面中的pageEncoding和contentType两种属性

    JSP页面中的pageEncoding和contentType两种属性 本文介绍了在JSP页面中经常用的两种属性,分别是pageEncoding和contentType,希望对你有帮助,一起来看. 关 ...

  7. python第三十五天-----作业完成--学校选课系统

    选课系统:角色:学校.学员.课程.讲师要求:1. 创建北京.上海 2 所学校2. 创建linux , python , go 3个课程 , linux\py 在北京开, go 在上海开3. 课程包含, ...

  8. 笨办法学Python(三十五)

    习题 35: 分支和函数 你已经学会了 if 语句.函数.还有列表.现在你要练习扭转一下思维了.把下面的代码写下来,看你是否能弄懂它实现的是什么功能. from sys import exit def ...

  9. python学习三十五天函数递归的用法

    python函数递归就是自己调用自己,无限循环,但是python限制了调用的次数1000次,就会终止,递归用在栏目分类,采集程序比较多,下面简单说函数递归用法和实例 1,函数递归用法 def func ...

随机推荐

  1. 【struts2】<package>的配置

    <package>元素可以把逻辑上相关的一组Action.Result.Intercepter等元素封装起来,形成一个独立的模块,package可以继承其他的package,也可以作为父包 ...

  2. [企业化NET]Window Server 2008 R2[3]-SVN 服务端 和 客户端 基本使用

    1.  服务器基本安装即问题解决记录      √ 2.  SVN环境搭建和客户端使用 2.1  服务端 和 客户端 安装    √ 2.2  项目建立与基本使用     √ 2.3  基本冲突解决, ...

  3. Linux高速缓冲区原理

    文件系统-高速缓冲区: 首先我们为什么需要高速缓冲区而不是直接访问块设备中的数据.这是因为,IO设备和内存之间的读写速度不匹配而且有一点数据需要写入或者读出磁盘就访问磁盘,磁盘很快就会损坏,而高速缓冲 ...

  4. Android启动Activity的标准Action和标准Category

    Android内部提供了大量标准的Action和Category常量. 其中用于启动Activity的标准Aciton及对应的字符串如下表所示: 启动Activity的标准Aciton Action常 ...

  5. Android颜色值(RGB)所支持的四种常见形式

    Android中颜色值是通过红(Red).绿(Green).蓝(Blue)三原色,以及一个透明度(Alpha)值来表示的,颜色值总是以井号(#)开头,接下来就是Alpha-Red-Green-Blue ...

  6. java类加载,简单认识

    java类加载,简单认识 在第一次创建一个类的对象或者第一次调用一个类的静态属性和方法的时候,会发生类加载 类加载期间,如果发现有静态属性,就给对应的静态属性分配内存空间,并赋值 这个过程完成之后,今 ...

  7. UITableView 滚动到最后一行

    if (self.tableView.contentSize.height > self.tableView.frame.size.height) { CGPoint offset = CGPo ...

  8. DCOS :私有云的物理基础架构管理引擎

    https://cloud.tencent.com/developer/article/1005598 一.引言 云计算经过多年的发展,逐渐从概念到渐为人认知.到接受.到现在全行业拥抱上云,云的客户也 ...

  9. DataTable 导入到Excel的最佳选择Npoi

    今天项目需要,自己先写了个,但老是觉得不完美.百度搜索了一下,现在网上主要流传2大插件,1是myxls,2是Npoi,听说后者主要是中国牛人的杰作,而且非常的强大,所以我就来试用下. 只是试用下,具体 ...

  10. matlab问题集总

    每次更新一点,慢慢增加 nargin nargin是用来判断输入变量个数的函数,这样就可以针对不同的情况执行不同的功能.通常可以用他来设定一些默认值,如下面的函数. 例子,函数test1的功能是输出a ...