看了本系列的前3篇,那么这次“重写服务器返回的内容”也就轻车熟路了。在Charles这,就没有不能改的东西。
永久重写
起因
一个接口可能会返回多种可能的数据,比如有success状态,有error状态等等,而success状态可能还有多种可能性。你需要针对性测试每一种可能性,而这时候,你如果要求服务器为你返回真实的所有可能的数据,那就麻烦大了,我们这时候需要能虚构数据。
操作步骤
-
先真实请求一次接口,右击接口选择Viewer Mappings,这样能找到接口的各种信息,先找个记事本存下来:
image.png -
打开Tools - Rewrite,开启Rewrite,然后开始Add。
image.png -
正常情况下,该接口会返回
"resultcode": 200,
和一些其他七七八八的数据,现在既然我要测试,那就意味着我要测试"resultcode"
为401
或者其他可能性,所以,我希望将"resultcode": 200,
先改成"resultcode": 401,
。
之后会发现,再请求的话,就是"resultcode": 401,
了。
BreakPoints重写
起因
如果并不需要永久重写,只想临时重写一次,那么还有一种方式,就是BreakPoints,用类似打断点的方式,手动修改某一次请求的数据。
BreakPoints不仅适用于临时修改接口response,也适用于临时修改静态文件,只不过更多的是用在修改接口上。
操作步骤
比如希望给 http://cj.sina.com.cn/articles/view/2103439601/7d5ff0f101900aqt8 修改几个字:
- 在Charles里右击文件,点击BreakPoints,点击之后并不会有什么反应,然后重新访问这个网址,Charles会立即跳出来,显示为:
- 上面这个界面是等待你修改Request,但是这次咱们做的实验并不打算修改Request,所以,直接点击右下角的Execute。屏幕一闪,会出现:
- 上面截图表示可以修改Response了,咱们编辑一下内容:
- 然后我们回到浏览器看一下,发现立即生效了:
说白了,所谓断点,就是中断程序的执行,原本浏览器发送请求和返回响应,都是一瞬间的事,现在,Charles把一瞬间变成了时间停止,你可以在时间停止的这段时间里做很多事情,然后Charles再继续让时间流逝,你的浏览器就会接到你修改后的内容了。就这么简单的原理。
网友评论