![](https://img.haomeiwen.com/i2028539/4486bc585358a2d2.png)
一、Map Local: 将指定的网络请求重定向到本地文件。
之所以首推这个功能,是因为我们可以随心所欲的让指定接口返回我们想要的内容,这样就可以在不借助测试给配数据的情况下,完成我们的调试。
1、选中接口,右键选择Save Response
,然后保存为.json
格式。
![](https://img.haomeiwen.com/i2028539/3020594ad6b5e29a.png)
2、将json编辑为我们期望的数据,然后选中接口,右键选择Map Local
。
![](https://img.haomeiwen.com/i2028539/bfed69f2354e1b59.png)
3、编辑map的本地路径。
![](https://img.haomeiwen.com/i2028539/da17c0d313bff44c.png)
4、如果想取消本地映射,可以在偏好里选择是取消所有的map local,还是指定接口的。
![](https://img.haomeiwen.com/i2028539/12fbc47599b0157c.png)
5、在接口未开发的情况下,我们仍然可以创建一个json文件,然后执行步骤三,去模拟接口请求。
6、目前,我测试的Query
参数,只对GET
请求有效,特此说明。Query参数可以限制只对传递指定参数的请求做本地映射处理。
![](https://img.haomeiwen.com/i2028539/83f83635a8f0ae4c.png)
二、Map Remote:更换远程接口地址,使用场景一般是,在不重新运行程序的情况下,将测试环境地址手动更改为生产环境等。
1、选中接口地址,右键“Map Remote”
![](https://img.haomeiwen.com/i2028539/5ca679f8cf10f890.png)
2、编辑想要替换的地址,保存即可。
![](https://img.haomeiwen.com/i2028539/9488dcc987009cd3.png)
3、同样,如果想取消远程映射,可以在偏好里选择是取消所有的map remote,还是指定接口的。
![](https://img.haomeiwen.com/i2028539/f4478d7b8feb3b5f.png)
三、修改网络请求:在与后台进行联调的时候,可能需要给后台传递不同的参数,但调试的入口又比较深,这时候Charles的“编辑请求”的功能就可以大显身手了。比如说,模拟登录,踢掉用户等等。
1、选中接口,然后选中钢笔(Compose)
![](https://img.haomeiwen.com/i2028539/53d60dfa6a192684.png)
2、可以任意编辑请求头、请求参数,然后可以选择执行、恢复更改和取消。
![](https://img.haomeiwen.com/i2028539/ce8f822fda5751e5.png)
四、模拟网速:App测试时一般都是用的公司的网络,速度还可以,如果想模拟网络环境非常差的情况下,会出现什么情况, Charles 也提供了对应的支持,来模拟低速网络环境。
1、进入Throttle设置
![](https://img.haomeiwen.com/i2028539/0e7876e3992eb565.png)
2、选择需要模拟的网络环境
![](https://img.haomeiwen.com/i2028539/b2c259f4ec2352b0.png)
3、可以通过点击面板上的小乌龟,来快捷的开关模拟网速
。
![](https://img.haomeiwen.com/i2028539/4e2b3a3641b01561.png)
五、断点调试
1、对要调试的接口打断点,并开启断点调试,如下图所示。
![](https://img.haomeiwen.com/i2028539/7a05fb50d4b71471.png)
2、当请求调试的接口时,Charles会先跳到编辑请求
,点击执行后,会跳到响应的编辑页面。我们在这里,可以对返回的结果进行编辑。
需要特别注意的是:如果timeoutInterval设置的时间过短,可能会造成在没有编辑完就超时的情况,建议如果编辑需要时间过长,我们就把timeoutInterval设置的足够长些。
![](https://img.haomeiwen.com/i2028539/25b084c45ad3398d.png)
![](https://img.haomeiwen.com/i2028539/c77d3a527147c859.png)
六、连续多次请求
![](https://img.haomeiwen.com/i2028539/ffb02451a2563673.png)
七、专注模式
像下图一样,把我们不关心的请求归到另一个文件夹里。
![](https://img.haomeiwen.com/i2028539/2626f89cd3f5a712.png)
操作方法:
![](https://img.haomeiwen.com/i2028539/99faf8db9341d396.png)
八、Find in: 在ULR、Header、RequestBody、ResponseHeader或ResponseBody里搜索字符串,正如你看到的,还支持正则表达式的搜索。
![](https://img.haomeiwen.com/i2028539/aac8bcc1d331156e.png)
拓展
原理简析
-
如果是HTTP请求,因为数据本身并没加密所以请求内容和返回结果是直接展现出来的。
-
但HTTPS是对数据进行了加密处理的,如果不做任何应对是无法获取其中内容。所以Charles做的就是对客户端把自己伪装成服务器,对服务器把自己伪装成客户端:
- Charles拦截客户端的请求,伪装成客户端向服务器进行请求;
- 服务器向“客户端”(实际上是Charles)返回服务器的CA证书;
- Charles拦截服务器的响应,获取服务器证书公钥,然后自己制作一张证书,将服务器证书替换后发送给客户端。(这一步,Charles拿到了服务器证书的公钥);
- 客户端接收到“服务器”(实际上是Charles)的证书后,生成一个对称密钥,用Charles的公钥加密,发送给“服务器”(Charles);
- Charles拦截客户端的响应,用自己的私钥解密对称密钥,然后用服务器证书公钥加密,发送给服务器。(这一步,Charles拿到了对称密钥);
- 服务器用自己的私钥解密对称密钥,向“客户端”(Charles)发送响应;
- Charles拦截服务器的响应,替换成自己的证书后发送给客户端;
当然,如果 用户不选择信任安装Charles的CA证书,Charles也无法获取请求内容。还有一种,如果 客户端内置了本身的CA证书,这时如果Charles把自己的证书发送给客户端,客户端会发现与程序内的证书不一致,不予通过,此时Charles也是无法获取信息的。
网友评论