姬長信(Redy)

Charles 从入门到精通

# 内容清单 - Charles 的简介 - 安装 Charles - Charles 初始化设置 - 过滤网络请求 - 截取HTTP/HTTPS数据 - 模拟弱网环境 - 修改网络请求 - 修改服务器返回内容 - 服务器压力测试 - 反向代理 - 解决与翻墙软件的冲突 ## Charles 的简介 **Charles** 是目前最主流的网络调试工具/uff08Charles、Fiddler、Wireshark.../uff09之一/uff0c对于一个开发者来说与网络打交道是日常需求/uff0c因此很多时候我们需要调试参数、返回的数据结构、查看网络请求的各种头信息、协议、响应时间等等。所以了解 Charles 并使用它 Charles 通过将自己设置为系统的网络访问代理服务器/uff0c这样所有的网络请求都会通过它/uff0c从而实现了网路请求的截获和分析。 Chareles 不仅可以分析电脑本机的网络请求/uff08HTTP 和 HTTPS/uff09/uff0c还可以分析移动端设备的网络请求。 Charles 是收费软件/uff0c作者开发出这样一个方便开发者使用的伟大工具/uff0c我们鼓励使用正版软件/uff0c但是对于一些囊中羞涩或者学生来说/uff0c有破解版的更好/uff0c别担心/uff0c这些我都准备好了/uff0c下一个 section 会讲解如何下载安装。 ## 安装 Charles - 方式1/uff1a[ Charles 官网地址](https://www.charlesproxy.com/download/)/uff0c根据你的电脑操作系统选择合适的下载方式。此时下载下来的是需要收费的/uff0c不差钱的同学当然可以直接购买。[购买链接](https://www.charlesproxy.com/buy/) - 方式2:按照方式1的方式去官网下载/uff0c然后下载相应 **[JAR包](https://pan.baidu.com/s/1QqSiEwMGIFrxwyKYg_6Kdw)**。这里以 MAC 为例/uff0c打 **Finder**/uff0c选择应用程序/uff0c选中 Charles/uff0c右击并选择/u201c显示包内容/u201d/uff0c看到 **Contents** 目录/uff0c点击进去选择 **Java** 文件夹/uff0c将下载下来的 **JAR包** 拖进去替换。至此/uff0c完成了 Charles 的破解。 ## Charles 初始化设置 Charles 的工作原理是将自身设置为系统的代理服务器来捕获所有的网络请求。所以使用 Charles /uff0c我们必须设置 Charles 为系统的代理服务器。 打开 Charles/uff0c当第一次启动的时候如果没有购买或者没有破解/uff0c会有倒计时/uff0c之后会看到软件的主界面/uff0c然后会请求你赋予它为系统代理的权限。点击授权会让你输入当前系统用户的密码。当然你也可以忽略或者拒绝该请求/uff0c然后等想要抓包的时候将它设置为系统的代理服务器。步骤/uff1a**选择菜单中的/u201cProxy/u201d -> "Mac OS X Proxy"。**如下图/uff1a ![Charles在MAC的初始化](https://user-gold-cdn.xitu.io/2018/7/18/164ac9aa738ccd2a?w=622&h=588&f=png&s=176517) 之后你的电脑上的任何网络请求都可以在 Charles 的请求面板中看到 看看 Charles 的主界面 ![Structure模式查看网络请求](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-004135@2x.png) ![Sequence模式查看网络请求](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-004435@2x.png) - 图上红色圈1:这里代表所有网络请求的展示方式。分别名为 /u201cStructure/u201d 和 /u201cSequence/u201d。 - Structure 将所有的网络请求按照域名划分并展示 - Sequence 将所有的网络请求按照时间排序并展示 - 图上红色圈2/uff1a一些的网络请求设置比如 HTTPS 以及端口等信息都在这个菜单栏设置 - 图上红色圈3/uff1a证书设置都在这里进行 ## 过滤网络请求 由于 Charles 可以将电脑或者设置过的手机的所有网络请求捕获到/uff0c而且我们分析网络传输应该是针对某个特定的网络下的抓包分析/uff0c为了清楚明显地看到我们感兴趣的网络请求通常会用到 Charles 的**/u201c过滤网络请求的功能/u201d**。 - 方法1:在 Charles 主面板的左侧所有网络请求的下方可以看到看到一个 **/u201dFilter/u201c** 输入栏/uff0c在这里你可以输入关键词来筛选出自己感兴趣的网络请求。比如我想分析的网络请求来自于/u201dwww.baidu.com" 下/uff0c你可以在下面输入"baidu"即可。 ![Filter 过滤网络请求](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-090550.png) - 方法2:在 Charles 菜单栏的顶部会看到 /u201cProxy/u201d 的选项/uff0c点击菜单栏选择 /u201cProxy/u201d -> "Recording Settings" 。选择 /u201cinclude/u201d。看到面板上面有一个 /u201cAdd/u201d 按钮/uff0c点击后在弹出的面板里面设置好我们需要分析的网络请求的**协议、主机名、端口、路径、参数**/uff0c当然你也可以只设置一些主要的信息/uff0c比如协议和主机名的组合。 ![Recording Settings 过滤网络请求](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-090926.png) - 方法3:一般打开 Charles 并设置好配置信息后/uff08比如电脑本机或者设置过代理的手机/uff09所有的网络请求都将在 Charles 的面板上显示/uff0c同时我们感兴趣的网络请求如果也在面板上显示的话/uff0c**/u201cStructure/u201d模式下**可以选中需要分析的网络请求/uff0c鼠标右击选择**/u201cFocus/u201d**。**/u201cSequence/u201d模式下**可以在面板的网络请求显示面板的右下角看到一个**Focus**按钮/uff0c点击勾选后 Charles 只会显示你感兴趣的网络请求。 ![Structure模式下Focus过滤网络请求](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/屏幕快照%202018-07-23%20上午9.22.39.png) ![Sequence模式下Focus过滤网络请求](https://github.com/FantasticLBP/knowledge-kit/blob/master/assets/WX20180723-092259.png?raw=true) ## 截取HTTP/HTTPS数据 ### 截取 HTTP 请求 Charles 的主要目的是抓取捕获网络请求/uff0c这里以 iPhone 的抓包为例讲解。 #### Charles 的设置 要截获 iPhone 的网络请求就需要为 Charles 开启代理功能。在菜单栏选择**/u201cProxy/u201d ->"Proxy Settings"**。填写代理的端口号并将**/u201cEnable transparent HTTP proxying/u201d**勾选上。 ![抓取手机网络请求的电脑端设置](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-092856.png) ### iPhone 上的设置 在电脑/u201c系统偏好设置/u201d中心打开网络查看本机 IP 地址/uff0c打开手机/u201c设置/u201d->/u201c无线局域网/u201d/uff0c进入当前使用的网络/uff0c点击进入当前 WIFI 的详情页/uff08可以看到当前 WIFI 的基本信息/uff0c包括子网掩码、端口、IP地址、路由器/uff09/uff0c在最下角可以看到**/u201cDNS/u201d和/u201cHTTP代理/u201d**2个section。我们点击**/u201c配置代理/u201d**/uff0c设置 HTTP 代理选中/u201c手动/u201d。服务器处填写电脑ip地址/uff0c端口写8888。设置好后/uff0c我们打开 iPhone 上的任意需要网络请求的应用/uff0c就可以看到 Charles 弹出请求的确认菜单/uff0c单击"Allow"按钮/uff0c即可完成设置。 ![抓取手机网络请求的手机端设置](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/11532309922_.pic.jpg) ### 截取 HTTPS 请求 如果你需要捕获 HTTPS 协议的网络请求/uff0c那么则需要安装 Charles 的 CA 证书。步骤如下/uff1b - 首先需要在 MAC 上安装证书。点击 Charles 顶部的菜单栏/uff0c选择 **/u201cHelp/u201d -> "SSL Proxying" -> "Install Charles Root Certificate"**。 ![HTTPS抓包电脑端证书安装](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/164ac9aa40822368.png) - 在 keychain 处将新安装的证书设置为永久信任 ![HTTPS抓包电脑端证书信任](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/164ac9aab5332151.png) - 即使安装了 CA 证书/uff0cCharles 默认是不捕获 HTTPS 协议的网络请求/uff0c所以我们需要对某个主机下的网络请求抓包分析的话/uff0c选中该网络请求右击选中 **/u201cSSL Proxying Enabled/u201d**。这样就可以看到我们感兴趣的HTTPS 网络请求了。 ![Charles确认开启抓取HTTPS](https://github.com/FantasticLBP/knowledge-kit/blob/master/assets/屏幕快照%202018-07-23%20上午9.47.09.png?raw=true) 如果你需要捕获移动设备的 HTTPS 网络请求/uff0c则需要在移动设备上安装证书并作简单的设置 - 选择 Charles 顶部菜单栏选择 **/u201cHelp/u201d ->"Install Charles Root Certificate on a Mobile Device or Remote Browser"**。然后就可以看到 Charles 弹出的安装说明了。 ![Charles提示手机端安装CA证书](https://github.com/FantasticLBP/knowledge-kit/blob/master/assets/WX20180723-101259.png?raw=true) - 在手机设置好 Charles 代理的情况下/uff0c在手机浏览器输入 **/u201cchls.pro/ssl/u201d**。安装提示下载好**CA证书**。 - 验证刚刚安装的 CA证书 ![描述文件的验证](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/164ac9a99ea05b2e.png) - iPhone 打开设置 -> 通用 -> 关于本机 -> 证书信任设置 -> 开启开关 ![手机端CA证书的信任](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/164ac9a9ca26c907.png) - 在 Charles 菜单栏 Proxy -> SSL Proxying Setting -> 点击 Add 按钮 -> 在弹出的对对话框设置需要监听的 HTTPS 域/uff08*:代表通配符/uff09 ![HTTPS抓包端口和主机设置](https://github.com/FantasticLBP/knowledge-kit/blob/master/assets/164ac9aaad2c0ff8.png?raw=true) - 设置完毕/uff0c尽情抓取你想要的 HTTPS 网络请求吧。 ![抓取京东HTTPS数据](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/164ac9a9a966fafe.png?raw=true) ## 模拟弱网环境 在平时开发的时候我们经常需要模拟弱网环境/uff0c并作弱网环境下的适配工作。Charles 为我们提供了这个服务。 在 Charles 菜单栏选择 **/u201cProxy/u201d -> "Throttle Settings"**。在弹出的面板上设置网络请求的参数/uff08上行/uff0c下行带宽、利用率、可靠性等等信息/uff09。如下图所示。 ![模拟弱网环境](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/屏幕快照%202018-07-23%20上午10.27.22.png?raw=true) 如果你想对**指定主机**进行弱网环境下的测试/uff0c可以点击上图的/u201cAdd/u201d按钮/uff0c在弹出的面板上设置协议、主机、端口来对指定的主机进行弱网设置。 ![设置指定网络请求的弱网模拟](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-102606.png?raw=true) ## 修改网络请求 对于捕获的网络请求/uff0c我们经常需要修改网络请求的cookie、Headers、Url等信息。Charles 提供了对网络请求的编辑和重发功能。只需要选中需要修改编辑的网络请求/uff0c在对应的右上角看到有一个/u201c钢笔/u201d的按钮/uff0c点击后就可以对选中的网络请求进行编辑了/uff0c编辑好后可以在右下角看到 **Execute** 按钮。这样我们编辑后的网络请求就可以被执行了。 ![修改网络请求](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-105440.png?raw=true) ## 修改服务器返回内容 很多时候为了方便调试代码/uff0c我们会有这种需求/uff0c修改接口返回的数据节点或者内容、甚至是状态码。比如数据为空、数据异常、请求失败、多页数据的情况。 Charles 为我们提供了超实用的功能/uff0c**/u201cMap/uff08Map Local、Map Remote/uff09功能/u201d、Rewrite功能、Breakpoints功能** /uff0c都可以实现修改服务端返回数据的功能。但是有区别和适用场景/uff1a - Map 功能适合长期地将某一请求重定向到另一个指定的网络地址或者本地 JSON 文件 - Rewrite 功能适合对网络请求进行一些正则替换 - Breakpoints 功能适合对网络请求进行一些临时性的修改/uff08类似于我们开发的断点作用/uff09 ### Map 功能 Map 功能分为 Map Local/uff08将某个网络请求重定向到本地 JSON 文件/uff09 和 Map Remote 功能/uff08将网络请求重定向到另一个网络接口/uff09。 在 Charles 菜单栏选择 **/u201cTools/u201d -> "Map Remote" 或 /u201cMap Local/u201d** 即可进入相应的功能模块。 #### Map Remote 功能 适合于切换线上到本地、测试服务到正式服务的场景。比如下图从正式服务切换到测试服务 ![Map Remote](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-113200@2x.png?raw=true) #### Map Local 功能 我们需要填写重定向的原地址信息和本地目标文件。我们可以先将某个接口的响应内容保存下来/uff08选择对应的网络请求/uff0c右击点击 **Save Response** /uff09成为 data.json 文件。然后我们编辑里面的 status 、message、data 等信息为我们想要的目标映射文件。 ![Save Response](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/屏幕快照%202018-07-23%20上午11.37.44.png?raw=true) 如下所示/uff0c我将一个网络请求的内容映射到我本地的一个 JSON 文件。之后这个请求的内容都从网络变为返回我本地的数据了。 ![Map Local](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-113951.png?raw=true) Map Local 可能会存在一个小缺陷/uff0c其返回的 HTTP Response Header 与正常的网络请求不一样/uff0c如果程序设置了校验 Header 信息/uff0c此时 Map Local 就会失败/uff0c解决办法是同时使用 **Rewrite功能**将相关的HTTP 头部信息 rewrite 成我们需要的信息 #### Rewrite 功能 Rewrite 适合对某个网络请求进行正则替换/uff0c以达到修改结果的目的。 假如我的 App 的界面上的显示的功能模块及其点击事件是根据接口来完成的/uff0c我想实现替换功能模块的名称的目的。步骤/uff1a点击顶部菜单栏的**/u201cTools/u201d -> "Rewrite"**。在弹出的面板上勾选 **/u201cEnable Rewrite/u201d**。点击左下角的 **Add按钮**/uff0c在右上角的 **Name/uff1a**处写好本次配置的名称/uff08如果有多个 Rewrite/uff0c为了后期容易区分/uff09。 - 可以针对特定的网络请求进行 Rewrite。可以点击右上角 **Location** 面板下面的 **Add按钮**。在弹出的面板上设置网络请求配置信息。注意此时需要同时设置 Protocol、Port、Host、Path信息/uff08我测试加了 Protocol、Host、Port这3个是无效的/uff09 ![Rewrite 针对特定网络请求的设置](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-115820.png?raw=true) - 然后对指定的 **Type** 和 **Action** 进行 Rewrite。 Type 主要有 Add Header、Modify Header、Remove Header、Host、Path等等。 Where 可以选择 Request 和 Response。指的是下面的修改是针对 Request 还是 Response ![Rewrite 设置范围](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-115855.png?raw=true) - 完成设置后点击 **Apply** 按钮/uff0c即可生效。下次继续请求该网络/uff0c返回的内容就是我们刚刚设置的内容。比如当前的/u201c政策法规/u201d要变成/u201c哈哈哈/uff0c我是假的政策法规/u201d。这时候就可以使用 Rewrite 功能 ![Rewrite 测试结果](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-114826.png?raw=true) #### Breakpoints 功能 Breakpoints 相比于其他几个修改网络请求的特点是只是针对当前的网络请求/uff0cBreakpoints 只存在于设置过的当前的网络请求/uff0cCharles 关闭后下次打开 Breakpoints 消失了。想要修改网络请求 Breakpoints 步骤最简单/uff0c跟我们调试工具里面设置的断点一样方便。 对于我们设置了 Breakpoints 的网络请求/uff0c Charles 会在下次继续访问该请求的时候停止掉/uff0c就跟 debug 一样。此时我们可以 **Edit Request**/uff0c修改过 Request 之后点击右下角的 **Execute** 按钮。然后等到服务端返回的时候继续是断点状态/uff0c此时可以 **Edit Response**。步骤/uff1a **选中某个网络请求 -> 右击 -> 点击/u201cBreakpoints/u201d。** 如下图/uff1a对该接口设置了 Breakpoints。请求网络后 Edit Response/uff0c点击 execute 后服务端返回的结果就是我们编辑的内容了。 ![对指定的网路请求设置断点](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-151811.png?raw=true) ![在Reponse的时候修改返回的数据](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-151850.png?raw=true) ![再次请求该接口返回的数据为我们设置过的](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-151906.png?raw=true) ## 服务器压力测试 我们可以使用 Charles 的 **Repeat** 功能地对服务器进行并发访问进行压力测试。步骤/uff1a**选中某个网络请求 -> 右击 -> Repeat Advanced -> 在弹出的面板里面设置总共的迭代次数/uff08Iterations/uff09、并发数/uff08Concurrency/uff09 -> 点击/u201cOK/u201d 。**开始执行可以看到以设置的并发数的规模/uff0c进行总共达设置的总共迭代次数的访问。/uff08专业的压力测试工具/uff1a**Load Runner**/uff09 ![简单压力测试](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-135943.png?raw=true) ## 反向代理 Charles 的反向代理功能允许我们将本地指定端口的请求映射到远程的另一个端口上。设置/uff1a**点击顶部菜单栏 Proxy -> 点击 Reverse Proxies**。 如下所示/uff0c我将本地的 8080 端口映射到远程的 80 端口上/uff0c点击 OK 生效后/uff0c当我继续访问本地的 80 端口/uff0c实际返回的就是远程 80 端口的提供的内容了。 ![反向代理设置](https://fantasticlbp.gitbooks.io/knowledge-kit/content/assets/WX20180723-141057.png?raw=true) ## 解决与翻墙软件的冲突 Charles 的工作原理是把自己设置为系统的代理服务器/uff0c但是我们开发者经常会利用 VPN 翻墙访问谷歌查找资料/uff08这些翻墙软件的工作原理也是把自己设置成为系统的代理服务器/uff09/uff0c为了2者和平共处。我们可以在 Charles 的 External Proxy Settings 中将翻墙的代理端口等信息填写。同时我们需要关闭翻墙软件的自动设置/uff0c更改为**/u201c手动模式/u201d**。/uff08使其不主动修改系统代理/uff09 ## 总结 Charles 功能强大、界面简洁/uff0c读完这篇文章并做出练习/uff0c相信你能很快掌握它/uff0c/u201c工欲善其事/uff0c必先利其器/u201d /uff0c掌握了它/uff0c相信可以为你大大提高开发中调试网络的效率。**Enjoy yourself** ## 参考链接 [唐巧的博客](http://blog.devtang.com/2015/11/14/charles-introduction/) /u200b