FiddlerScript学习一:修改Request或Response

前两天因项目需要,简单看了一下FiddlerScript,功能挺强的,今天有时间仔细看一下,做个笔记。

修改Request或Response

修改Request和Response要在FiddlerScript中的OnBeforeRequest和OnBeforeResponse函数中添加规则即可。OnBeforeRequest函数是在每次请求之前调用,OnBeforeResponse函数是在每次响应之前调用。

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:

即图中红色标注出来的部分。图中黄色标注出来的部分有点特殊,host为Tunnel to ,url为另一host。查看该请求的Header为:

这种特殊情况会在下面还有例子。

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

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

 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";

7、Simulate the Windows HOSTS file, by pointing one Hostname to a different IP address. (Retargets without changing the request’s Host header)

// All requests for subdomain.example.com should be directed to the development server at 128.123.133.123
if (oSession.HostnameIs(“subdomain.example.com”)){
oSession.bypassGateway = true; // Prevent this request from going through an upstream proxy
oSession[“x-overrideHost”] = “128.123.133.123”; // DNS name or IP address of target server
}
8、Retarget requests for a single page to a different page, potentially on a different server. (Retargets by changing the request’s Host header)

if (oSession.url==”www.example.com/live.js”) {
oSession.url = “dev.example.com/workinprogress.js”;
}
9、Prevent upload of HTTP Cookies

oSession.oRequest.headers.Remove(“Cookie”);
10、Decompress and unchunk a HTTP response, updating headers if needed

// Remove any compression or chunking from the response in order to make it easier to manipulate
oSession.utilDecodeResponse();
11、Search and replace in HTML.

if (oSession.HostnameIs(“www.bayden.com”) && oSession.oResponse.headers.ExistsAndContains(“Content-Type”,”text/html”)){
oSession.utilDecodeResponse();
oSession.utilReplaceInResponse(‘’,’’);
}
12、Case insensitive Search of response HTML.

if (oSession.oResponse.headers.ExistsAndContains(“Content-Type”, “text/html”) && oSession.utilFindInResponse(“searchfor”, false)>-1){
oSession[“ui-color”] = “red”;
}
13、Remove all DIV tags (and content inside the DIV tag)

// If content-type is HTML, then remove all DIV tags
if (oSession.oResponse.headers.ExistsAndContains(“Content-Type”, “html”)){
// Remove any compression or chunking
oSession.utilDecodeResponse();
var oBody = System.Text.Encoding.UTF8.GetString(oSession.responseBodyBytes);

// Replace all instances of the DIV tag with an empty string
var oRegEx = /

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ios and Android

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值