一、 巧用代理抓包。

首页,需设置Tools——>Fiddler Options——>Connectons,维护代理端口及允许其他设备连接。

这里,需要注意的是端口配置不能重复,抓包代理设置时,要同这个一致的。

1. 浏览器:当fiddler启用就自动开启代理了,故不描述。

2. PC端app:

以淘宝千牛PC为例,若需要抓他的插件的包,怎么设置

找到应用的设置——>网络——>启用代理,如图所示服务器、端口要与你抓包所配置的一致哦。一般启用代理后,该app需重启。

注:这里服务器127.0.0.1是因为我这个是抓本机的,所以地址是这个。

怎么知道代理的IP地址呢,可以直接看代理机器获取的IP,也可以看fiddler,如图所示,看Online信息的地址即可。

3. 移动端:(可以参考http://www.cnblogs.com/TankXiao/p/3063871.html)

类似pc,移动端app代理时,需要开启电脑无线wifi。这样手机才可以链接到电脑的代理。

开启无线wifi,然后开启fiddler。

然后呢,手机端无线链接到开启的wifi,然后设置无线的HTTP代理。如图所示

注:配置一个后就可以通过修改电脑端hosts文件来配置程序位置了,很是方便,这样也跨过越狱修改手机hosts来进行测试。


二、以上的仅抓取HTTP的设置,如果需要抓取HTTPS。除了上述的步骤,还需要配置。

1. 配置Fiddler,Tools—>Fiddler Options,如图

配置Decrypt HTTPS traffic,选中后就可以截获HTTPS请求了(注意:配置完要重启Fiddler哦)

2. iphone安装证书

为了能抓取iphone手机的HTTPS请求,还得安装证书(HTTP是不需要的),其他配置同上,就是多个证书的安装。

1)fiddler配置、无线配置代理,同上步骤

2)使用safari,打开你的代理的地址http://192.168.*.*:8888(地址就是你配置无线代理的IP与端口,当然反正是fiddler所在的地址及端口即ok,方法也在上面介绍过了)

如上图所示,选择FiddlerRoot certificate安装证书即可。

经过以上配置后,再来试试抓取iPhone手机的https包吧。


三、修改Request和Response信息

学习的是FiddlerScript对OnBeforeRequest和OnBeforeResponse2个函数进行修改。

1、添加请求头Header

oSession.oRequest["NewHeaderName"] = "New header value";

2、删除Response的Header

oSession.oResponse.headers.Remove("Set-Cookie");

3、将请求从一个页面转发到同一Server上的另一页面

if (oSession.PathAndQuery=="/hello/hello.html") {

oSession.PathAndQuery="/hello/index.html";

}

注意:oSession.PathAndQuery的值为fiddler中session列表中的Url:

上面的例子,拦截请求地址为/hello/hello.html的请求,并将其转发到相同Server的/hello/index.html

4、将请求转发到相同端口号的不同服务器(修改请求的Host)

<pre name="code" class="javascript"> if(oSession.HostnameIs("www.baidu.com")){

oSession.hostname = "www.sina.com.cn";

}

这个例子是将发送到百度的请求转发到新浪,则会提示页面不存在。这里只是改变了host,并不改变后面的地址,因此, 如果在新浪上不存在相应的页面。

如果我访问的是如下地址:http://www.baidu.com/link?url=CQuVpjo9u9UQADcstwECPEmrziPMk5u5H9PlRN2TbWLkKZaxafVER2X8OEYzovr-yasX2Fwcgj0NANBtKVj0gN78jNJ3bXTmIsTeBk7hXem

则结果如下:(该页面实际是存在的,是百度搜索出来的结果页面,被fiddler转发到新浪,但是新浪上不存的此页面)

5、将请求转发到不同端口号,不同Server

if (oSession.host=="192.168.0.70:8080") {

oSession.host="192.168.0.69:8020";

}

这个例子是将发送到192.168.0.70:8080的请求转发到192.168.0.69:8020,这里只是改变host,并不改变后面的请求地址。例如,做以上的规则后,我请求的是:

http://192.168.0.70:8080/hello/hello.html

而实际我项目部署到的是:192.168.0.69:8020

6、将所有请求从一个服务器转发到另一个服务器,包括Https

// Redirect traffic, including HTTPS tunnels

if (oSession.HTTPMethodIs("CONNECT") && (oSession.PathAndQuery == "www.example.com:443")) {

oSession.PathAndQuery = "beta.example.com:443";

}

if (oSession.HostnameIs("www.example.com")) oSession.hostname = "beta.example.com";

暂总结记录这些,后期补充

Fidder学习基础(二)的更多相关文章

  1. TP5学习基础二:目录结构、URL路由、数据操作

    一.安装1.使用git或者composer(composer update)进行实时更新,区别在于git不会清空核心框架目录而composer会清空.2.使用官网打包好的TP压缩包(解压即可用)-&g ...

  2. Redis学习基础二

    回顾:上一基础中已了解 ( 什么是redis .redis 的三大特点.安装,和数据配置) 接下来浅尝Redis的数据类型,时间煮雨...... 一.Redis数据类型 redis支持五中数据类型(s ...

  3. C++学习基础二——指针与引用的区别

    一.指针: (1)如果对指针进行解引用操作 赋值,改变的是指针所指向对象的值:(2)如果不对指针进行解引用操作 赋值,则改变的是指针本身的值:(3)const指针本身的值不能修改,但是const指针所 ...

  4. JavaScript学习 - 基础(二) - 基础类型/类型转换

    基础类型 - 数字类型(Number) 1.最基本的数据类型 2.不区分整型数值和浮点型数值 3.所有数字采用64位浮点格式存储,相当于Java和C语言中double格式 4.能表示的最大值 +- 1 ...

  5. AspectJ基础学习之二搭建环境(转载)

    AspectJ基础学习之二搭建环境(转载) 一.下载Aspectj以及AJDT 上一章已经列出了他的官方网站,自己上去download吧.AJDT是一个eclipse插件,开发aspectj必装,他可 ...

  6. opengl基础学习专题 (二) 点直线和多边形

    题外话 随着学习的增长,越来越觉得自己很水.关于上一篇博文中推荐用一个 学习opengl的 基于VS2015的 simplec框架.存在 一些问题. 1.这个框架基于VS 的Debug 模式下,没有考 ...

  7. 2、JavaScript 基础二 (从零学习JavaScript)

     11.强制转换 强制转换主要指使用Number.String和Boolean三个构造函数,手动将各种类型的值,转换成数字.字符串或者布尔值. 1>Number强制转换 参数为原始类型值的转换规 ...

  8. 数据库学习---SQL基础(二)

    数据库学习---SQL基础(一) 数据库学习---SQL基础(二) 数据库学习---SQL基础(三) 上篇复习的sql的增删改查,and ,or ,>=, <=,!=等逻辑运算符,还有in ...

  9. 【笔记】MySQL的基础学习(二)

    [笔记]MySQL的基础学习(二) MySQL 老男孩  一 视图 视图其实就是给表起个别名 1.创建视图 格式:CREATE VIEW 视图名称 AS SQL语句 CREATE VIEW v1 AS ...

随机推荐

  1. (原创).Net将EF运用于Oralce一 准备工作

    网上有很多EF运用于Oracle的博文,但是找了半天发现大多数博文大都语焉不详,于是决定自己折腾. 首先我的开发工具为vs2010,那么最适用于VS2010的EF版本为多少呢?答案是EF5.我在Sta ...

  2. rabbit工作队列模式

    工作队列比简单队列在消费者这边多了一个方法. channel.basicQos(1);公平队列消费(参数设置为1,表示消费者消费完一条才会去接受再次发来的消息) 生产者: package com.kf ...

  3. java四大特性详解

    Java的四大基础特性一.抽象 父类为子类提供一些属性和行为,子类根据业务需求实现具体的行为. 抽象类使用abstract进行修饰,子类要实现所有的父类抽象方法否则子类也是抽象类.二.封装 把对象的属 ...

  4. CentOS 7.2 安装 MySQL 5.6.24

    说明:由于甲骨文公司收购了MySQL后,有将MySQL闭源的潜在风险,因此CentOS社区采用mysql的MariaDB分支的方式来避开这个风险. 所以需要先加入yum的仓库,才能利用yum来安装my ...

  5. 【转载】RocketMQ与Kafka对比(18项差异)

    转载自 https://github.com/alibaba/RocketMQ/wiki/rmq_vs_kafka RocketMQ与Kafka对比(18项差异) 淘宝内部的交易系统使用了淘宝自主研发 ...

  6. 执行shell脚本报错:syntax error near unexpected token `或syntax error: unexpected end of file

    引起此问题最可能的原因是: 在windows下编写的文件上传到linux执行. 我是在notepad++上编写的代码,之后上传到linux执行,报此错误.仔细检查,语法方面没有错误.上网查了一下,发现 ...

  7. spring和jdbc结合的一个小例子

    1.新建一个SpringJdbc的maven项目. 2.引入需要的jar包的依赖 <span style="white-space:pre"> </span> ...

  8. ECMAScript5提供了9个新数组方法:遍历、映射、过滤、检测、简化、和搜索数组

    大多数方法的第一个参数接收一个函数,并且对数组的每个元素调用一次该函数.如果是稀疏数组,对不存在的元素不调用传递的函数.在大多数情况下,调用提供的函数使用三个参数:数组元素,元素的索引,数组本身,通常 ...

  9. 浅谈jquery中prop()和attr()

    我们都知道,一般在jquery中设置属性时要用到attr()方法,现在我们有一个效果,点击按钮切换复选框的选中状态,下面贴出html代码: <input type="checkbox& ...

  10. avalon2简单数据绑定(自定义属性绑定)

    <!DOCTYPE html> <html> <head> <title>项目</title> <meta charset=" ...