重写服务器响应内容,Charles系列4:重写服务器返回的内容

看了本系列的前3篇,那么这次“重写服务器返回的内容”也就轻车熟路了。在Charles这,就没有不能改的东西。

永久重写

起因

一个接口可能会返回多种可能的数据,比如有success状态,有error状态等等,而success状态可能还有多种可能性。你需要针对性测试每一种可能性,而这时候,你如果要求服务器为你返回真实的所有可能的数据,那就麻烦大了,我们这时候需要能虚构数据。

操作步骤

先真实请求一次接口,右击接口选择Viewer Mappings,这样能找到接口的各种信息,先找个记事本存下来:

3d7c99881971

image.png

打开Tools - Rewrite,开启Rewrite,然后开始Add。

3d7c99881971

image.png

正常情况下,该接口会返回"resultcode": 200,和一些其他七七八八的数据,现在既然我要测试,那就意味着我要测试"resultcode"为401或者其他可能性,所以,我希望将"resultcode": 200,先改成"resultcode": 401,。

3d7c99881971

image.png

之后会发现,再请求的话,就是"resultcode": 401,了。

BreakPoints重写

起因

如果并不需要永久重写,只想临时重写一次,那么还有一种方式,就是BreakPoints,用类似打断点的方式,手动修改某一次请求的数据。

BreakPoints不仅适用于临时修改接口response,也适用于临时修改静态文件,只不过更多的是用在修改接口上。

操作步骤

在Charles里右击文件,点击BreakPoints,点击之后并不会有什么反应,然后重新访问这个网址,Charles会立即跳出来,显示为:

3d7c99881971

image.png

上面这个界面是等待你修改Request,但是这次咱们做的实验并不打算修改Request,所以,直接点击右下角的Execute。屏幕一闪,会出现:

3d7c99881971

image.png

上面截图表示可以修改Response了,咱们编辑一下内容:

3d7c99881971

image.png

然后我们回到浏览器看一下,发现立即生效了:

3d7c99881971

image.png

说白了,所谓断点,就是中断程序的执行,原本浏览器发送请求和返回响应,都是一瞬间的事,现在,Charles把一瞬间变成了时间停止,你可以在时间停止的这段时间里做很多事情,然后Charles再继续让时间流逝,你的浏览器就会接到你修改后的内容了。就这么简单的原理。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值