之前我们讲到过fiddler(https://www.cnblogs.com/zichliang/p/16067941.html),wireshark(https://www.cnblogs.com/zichliang/p/17477251.html)
今天我们来讲讲另一款跨平台的抓包软件——Charles
Charles是一个HTTP代理服务器,HTTP监视器,反转代理服务器,当浏览器连接Charles的代理访问互联网时,Charles可以监控浏览器发送和接收的所有数据。它允许一个开发者查看所有连接互联网的HTTP通信,这些包括request, response和HTTP headers (包含cookies与caching信息)。
Charles 通过将自己设置成系统的网络访问代理服务器,使得所有的网络访问请求都通过它来完成,从而实现了网络封包的截取和分析。
除了在做移动开发中调试端口外,Charles 也可以用于分析第三方应用的通讯协议。配合 Charles 的 SSL 功能,Charles 还可以分析 Https 协议。
Charles 是收费软件,可以免费试用 30 天。试用期过后,未付费的用户仍然可以继续使用,但是每次使用时间不能超过 30 分钟,并且启动时将会有 10 秒种的延时。
后面可以通过某些手段去除掉这十秒的等待时间。但即使你不付费也依然可以正常使用完整功能。
这里贴上官网:Charles Web Debugging Proxy • HTTP Monitor / HTTP Proxy / HTTPS & SSL Proxy / Reverse Proxy
破解地址:Charles破解工具
直接打开上文官网
接着选择我们对应的系统即可
这里可以看到charles支持的系统比较多。这也是相对于fiddler比较良好的一点。
安装下来直接傻瓜式安装即可。
移动端用charles抓包,先在电脑上安装charles软件。然后添加相关配置。proxy settings
SSL proxying settings
为了可以进行https的抓包,一般需要配置一下ssl proxying settings。在菜单栏Proxy -> SSL proxying settings, 勾选Enable SSL Proxying,并添加location配置,如下:
首先我们打开charles简单看看整个页面
可以看到 大体分为三个部分
菜单栏
工具栏
主界面
而主界面又分以下几个部分
左侧:
右侧:
new session:新建会话
open session:打开会话
clear session:清除会话内容(与导航菜单中得笤帚是一样的功能)
close session:关闭会话
save session:保存会话
save session as:另存会话为
import:导入
export session:导出
quiet:关闭软件
Edit:
cut: 剪切某个会话
Copy: 复制某个会话
Paste: 粘贴某个会话
Select All: 选择所有的会话
Find in Session: 查找某个会话中的信息
Find Next : 查询下一条
Find Previous: 查询上一条
Preferences: 外观等配置
Views:
视图菜单里的东西其实是非常常用的功能,下文介绍请求内容和相应内容会提到。
视图导航栏
Charles 主要提供两种查看封包的视图,分别名为Structure和Sequence。
两者区别:
使用时可以根据具体的需要在这两种视图之前来回切换。
接口信息列表栏
在Structure 视图
下面是展示每个域名所抓到的数据包,点击【+】可查看具体详细信息 展开该host 域名下的所有请求
请求内容区
Overview:展示当前请求的一个大体情况
content:展示当前请求的具体内容和服务器的相应内容
summary:展示当前请求的大体资源分布情况
chart:以表格形式告诉我们接口响应时间的分布情况
notes:笔记,点击后自己可以对当前请求记录一些东西,方便后续查看该接口的用途,可在overview中查看
请求内容导航栏
Headers:当前请求的头信息
Text:文本形式展示当前接口请求内容
Hex:十六进制展示,一般不使用
JSON:以json格式展示当前接口请求内容
JSON Text:以json text格式展示当前接口请求内容
Raw:源码展示当前接口请求内容
响应内容导航栏
Headers:响应的头信息
Text:文本形式展示响应内容
Hex:十六进制展示,一般不使用
JavaScript:以JavaScript格式查看响应内容内容
JSON:以json格式查看响应内容内容
JSON Text:以JSON Text格式查看响应内容内容
Raw:源码形式展示响应内容
Charles 会自动配置浏览器和工具的代理设置,所以说打开工具直接就已经是抓包状态了。只需要保证一下几点即可:
手机抓包的原理,和 PC 类似,手机通过把网络委托给 Charles 进行代理与服务端进行对话。具体步骤如下:
HTTPS 的抓包需要在 HTTP 抓包基础上再进行设置。需要完成一下步骤:
参考文档: 测试工具Charles(四)——主界面介绍_麥女孩的小火柴的博客-CSDN博客Charles 功能介绍和使用教程 - 知乎