美文网首页
Charles系列4:重写服务器返回的内容

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

作者: microkof | 来源:发表于2018-07-26 12:05 被阅读154次

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

    永久重写

    起因

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

    操作步骤

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


      image.png
    2. 打开Tools - Rewrite,开启Rewrite,然后开始Add。


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

    image.png

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

    BreakPoints重写

    起因

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

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

    操作步骤

    比如希望给 http://cj.sina.com.cn/articles/view/2103439601/7d5ff0f101900aqt8 修改几个字:

    1. 在Charles里右击文件,点击BreakPoints,点击之后并不会有什么反应,然后重新访问这个网址,Charles会立即跳出来,显示为:
    image.png
    1. 上面这个界面是等待你修改Request,但是这次咱们做的实验并不打算修改Request,所以,直接点击右下角的Execute。屏幕一闪,会出现:
    image.png
    1. 上面截图表示可以修改Response了,咱们编辑一下内容:
    image.png
    1. 然后我们回到浏览器看一下,发现立即生效了:
    image.png

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

    相关文章

      网友评论

          本文标题:Charles系列4:重写服务器返回的内容

          本文链接:https://www.haomeiwen.com/subject/qzhmmftx.html