前言

Charles 其实是一款代理服务器,通过成为电脑或者浏览器的代理,然后截取请求和请求结果达到分析抓包的目的。其次该软件是用 Java 写的,能够在 Windows,Mac,Linux 上使用。

什么是抓包?

抓包(packet capture)就是将网络传输发送与接收的数据包进行截获、重发、编辑、转存等操作,也用来检查网络安全。抓包也经常被用来进行数据截取等。

Charles 主要功能

  • 支持 SSL 代理。可以截取分析 SSL 的请求。
  • 支持流量控制。可以模拟慢速网络以及等待时间(latency)较长的请求。
  • 支持重发网络请求,方便后端调试。
  • 支持修改网络请求参数。
  • 支持网络请求的截获并动态修改。

PS:Charles 是收费软件,可以免费试用 30 天。试用期过后,未付费的用户仍然可以继续使用,但是每次使用时间不能超过 30 分钟,并且启动时将会有 10 秒种的延时。

开始抓包

默认,他会把电脑设置为代理,这样你会发现,你通过浏览器请求到网址都会出现在这里。

通常点击某一个网址后,你会发现右边会出现这个网址请求的大概信息,点击具体的请求后会出现 request 和 response 等信息

但是你会发现 https 都是 unknown ,这时候就需要我们安装证书啦。

安装 ssl ca 证书

  • 配置 Charles 证书;选择 help —> SSL Proxying -> install Charles Root Certificate,就会出现如下界面

  • 点击安装证书再点击,安装在“受信任的根证书颁发机构” ,这一步十分重要,如不在这个目录下,则不能抓取 https 请求

之后无脑下一步就安装完成啦

配置 SSL Proxy Settings

添加上证书后,会发现还是不能抓取 https 请求,这是因为我们还没有配置 ssl 的代理,接下来我们配置一下

在 Proxy -> SSL Proxy Settings,然后选择 Enable SSL Proxying,在点击 Add

ps: 通常 https 默认端口就是 443,所以这里我们通过匹配符 *:443 就可以抓取大部分的 https 请求了

打开百度

搜索一下 12306 就会出现百度根据 12306 查询关联的下拉列表请求了

到这里,基本的 https 抓包就可以使用了

接下来,我们连接真机进行真机的抓包体验。。。

手机安装证书

首先,手机和电脑需要在同一个局域网才可以进行抓包

这里会告诉我们,用手机浏览器打开 chls.pro/ssl 就可以安装证书了

先手动配置下代理,打开 WIFI,设置,代理填写刚刚的 ip 地址,具体如图:

打开后会出现是否允许设备连接 Charles,点击 allow 即可

手机端访问 chls.pro/ssl,下载证书就可以安装了

这里还是以百度为例,手机访问百度之后再次搜索 12306, 同样会出现下面的下拉列表:

Charles 就会截取我们请求这个地址的数据,如图所示:

这样子就实现了我们的真机抓包啦。

安卓端

ps: 可能是因为我这里之前装过证书了,所以可以抓包成功,实际上安卓 7.0 以上因为一些安全政策,不允许将证书安装到信任目录,想实现抓包则需要将下载的证书复制到/system/etc/security/cacerts/目录

解决条件:手机需要 root

参考链接:Android9.0 配置 charles 的 https 抓包,android 9.0 以上 charles https 抓包

ps: openssl 直接在 gitbash 就可以使用了,所以上面的操作直接在 gitbash 即可

ios 端

ios 配置比安卓简单了许多,安装完后只需要在 wifi 中设置代理,在之后 打开设置 -> 关于本机 -> 证书信任设置,打开完全信任开关。就可以抓包了。

ps:因为手机抓包,截图不方便,所以下面用 pc 来讲解其他内容,实际使用是一样的

Throttle Setting 模拟网速

有时候在开发的时候我们想要模拟一下网络慢的情况,这时候 Charles 他是可以帮助到你的,在 Proxy -> Throttle Setting,然后选择 Enable Throttling,在 Throttle Preset 下选择网络类型即可,具体设置你可以自行拿捏。

Breakpoints 断点

Charles 发起一个请求的时候,我们是可以给某个请求打一个断点的,然后来观察或者修改请求或者返回的内容,但是在这过程中要注意请求的超时时间问题。要针对某一个请求设置断点,只需要在这个请求网址右击选择 Breakpoints 就可以断点某一个请求了。

这里我们以简书的右侧推荐作者为例,

右键,打上断点,刷新一下

通过右侧的 Edit Request 就可以修改我们的请求参数啦

比如,我们把 count 修改为 2,则页面返回的数据只有两条了

Rewrite Settings 内容替换

有时候我们会测一下请求的参数不同会带来不同的返回结果以测试是否达到业务需求,或者需要不同的返回结果来验证我们对数据的处理是否正确,这时候需要后台的同事配合,但是有了 Charles,我们可以自己把控接口返回来的内容,比如数据的空与否,数据的长短等等。

再或者,修改别人的 app 里面接口的返回值,供做一些自己想做的事

击 Tools -> Rewrite Settings , 就可以使用我们的内容替换了,同样是以全部渠道这个接口为例

点击 enable,启用该功能(事先复制好接口链接),点击 Add 添加一个重写配置,这里命名为 Test

点击右下 add 按钮,选中 body ,设置要修改的字符,修改即可

这里有个小问题,因为我们修改的是中文,所以我们需要在返回的数据 Header 中 Content-Type 字段声明 charset=UTF-8。即:

修改完成后,我们看下界面的变化,是不是所有 乔汉童 都变成了 磨蹭先生

Map Remote 请求重定向

求重定向的作用是什么呢?开发中一般都是测试环境,如果我们想对比一下和线上版本的区别的话,可以讲测试的请求重定向到正式环境下。在选择 Tools -> Map Remote 下:

ps: 其实这个和重写作用类似,但是比重写适用性更广,而且更可控

和 Rewrite 操作类似,我们同样需要点击 enable ,之后输入我们需要重定向的地址

映射数据如下:

{
"users": [
{
"id": 5796592,
"slug": "86b81ed8e35c",
"nickname": "磨蹭先生",
"avatar_source": "https://cdn.jsdelivr.net/gh/GATING/blog_imgs@master/blog/avatar.png",
"total_likes_count": 200044,
"total_wordage": 36871100,
"is_following_user": false
}
],
"total_count": 41931
}

这里主要修改了第一个数据,我们看看效果

发现,数据的确发生了改变,也实现了我们的目的

最后

感谢各位观众老爷的观看啦,Charles 还有一下其他的妙用。就等着各位慢慢的去发掘吧!

Charles(青花瓷/花瓶)的基本使用的更多相关文章

  1. 浅谈Charles —— 青花瓷

    Charles -- 青花瓷 网络抓包工具 可以拦截 iPhone/Android 手机中 App 的非加密网络请求数据 使用 手机&电脑在同一个局域网 确保电脑能够通过路由器访问互联网 电脑 ...

  2. 青花瓷运用->下载历史版本App

    1.软件准备 [必备]Charles4.0.1 下载密码: jfnk [不需要,配合Charles食用效果更佳]Paw2.3.1 下载密码: t3my 2.正式开始 2.1 打开Charles青花瓷 ...

  3. HTTP缓存&代理

    一.与缓存有关的Header 1.Request If-Modified-Since:  缓存文件的最后修改时间 If-None-Match:                             ...

  4. 下载历史版本App超详细教程

    有些时候我们需要下载旧版本的 App 进行研究或者其他用途,然而在 iOS 下,苹果的 App Store 里面默认只能下载最新版本的 App,对滴,就是这么任性,不服不行.然而在 Android 里 ...

  5. 下载历史版本App

    文/timhbw(简书作者)原文链接:http://www.jianshu.com/p/edfed1b1822c著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 1.软件准备 [必备]C ...

  6. iOS使用Charles(青花瓷)抓包并篡改返回数据图文详解

    写本文的契机主要是前段时间有次用青花瓷抓包有一步忘了,在网上查了半天也没找到写的完整的教程,于是待问题解决后抽时间截了图,自己写一遍封存在博客园中以便以后随时查阅. charles又名青花瓷,在iOS ...

  7. ios 抓包工具 ios青花瓷charles

    iOS_青花瓷Charles抓包,ios青花瓷charles 使用青花瓷Charles抓取手机端的网络请求: 第一步,下载安装并打开Charles 第二步,去掉菜单[Proxy]以下的[Mac OSX ...

  8. iOS_青花瓷Charles抓包

    使用青花瓷Charles抓取手机端的网络请求: 第一步,下载安装并打开Charles watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcHJlX2VtaW5l ...

  9. 使用青花瓷(charles)抓包

    官网下载charles: https://www.charlesproxy.com/download/ MAC & Apple 打开青花瓷charles 找到本地IP:青花瓷里面Help-&g ...

随机推荐

  1. Redis 6.0 多线程重磅发布!!!

    Redis 6.0在5.2号这个美好的日子里悄无声息的发布了,这次发布在IT圈犹如一颗惊雷一般,因为这是redis最大的一次改版,首次加入了多线程. 作者Antirez在RC1版本发布时在他的博客写下 ...

  2. java开发常见单词(复习整理)

    开发中基本都能碰到,不止以下单词,后续会添加,javascript.html.mysql.spring.Linux中常用单词于此合并分类,特殊不常见不添加 访问修饰符4个--------------- ...

  3. PHPExcel生成Excel文件---提示导出文件或者文件扩展名不一致,或导出的文件或文件扩展名无效

    $data = Db::name('shop_cart')->where('phone','15555555555')->select(); $objPHPExcel = new PHPE ...

  4. yum命令无效

    无论执行任何yum命令都无效,弄了两个小时.主要的方案有: 方案1:yum clean all 并查询repo中是否有enabled=0: https://unix.stackexchange.com ...

  5. HTTP响应格式

    HTTP响应格式

  6. 利用js实现 禁用浏览器后退| 去除上一个历史记录链接

    也是查找了好多资料才找到的,这种方式,可以消除 后退的所有动作.包括 键盘.鼠标手势等产生的后退动作. <script language="javascript"> / ...

  7. CF918C The Monster

    题目链接:http://codeforces.com/contest/918/problem/C 知识点: 贪心 解题思路: 枚举起点(当起点就是\(')'\)时直接跳过)并在此基础上遍历字符串,用一 ...

  8. UVa 11529

    题目大意:见刘汝佳<算法竞赛入门经典——训练指南>P173 解题思路: 先求出对于每一个点,有多少个三角形包含它,把各个点得到的数值加起来的总和除以 C[n][3] 即可得出答案.对于每一 ...

  9. 求平均成绩(hdu2023)

    注意:要心细,不要错在小细节上.如int c[6];double agve; c[j]=agve:这是错误的. #include<stdio.h> #include<cmath> ...

  10. Nginx 运维(安装与使用)

    Nginx 运维(安装与使用) 普通安装 Windows安装 (1)进入官方下载地址,选择合适版本(nginx/Windows-xxx). (2)解压到本地 (3)启动 下面以 C 盘根目录为例说明下 ...