charles抓包原理

基础概念

1. CA

CA是证书颁发机构,不是随便什么人都能成为证书颁发机构,关键是你颁发的证书要别人认可。别人认可你才会内置你的证书(机构证书,也称根证书)。

2. TSL证书

TSL证书是指用于https通信,客户端验证服务端的合法性的一个数据包。

证书内容

服务提供者的基本信息和证书颁发机构和使用的算法和域名等+该服务的公钥+证书签名

证书签名怎么产生

服务提供者的基本信息先取hash,再用CA机构的私钥加密。

3. 根证书

CA机构的证书,客户端内置(最常见的就是浏览器厂商内置主流机构的证书)

4. 证书链

下级证书的签名是使用上级证书的私钥加密产生的,所以因为这个关联关系形成了一个链条。

5. 证书校验过程

step1 服务端发送自己的证书给客户端

step2 客户端读取证书颁发机构

step3 客户端找到本地对应机构的证书

step4 客户端那机构证书公钥解密服务器证书签名

step5 客户端拿证书信息作hash,与step4解密的内容对比,相等并且基本信息中的域名跟当前访问的域名一致则通过。

charles抓包原理

charles的根证书

charles自己做了一个根证书,你想要用charles抓包,第一步你要内置他发布的根证书。

charles伪造证书

charles用他自己的证书给你服务端的域名做一个证书。

charles作为中间人的流程

step1 拦截客户端请求

step2 发送他伪造的证书给客户端

step3 因为你内置了charles的根证书,所以该证书能校验通过

step4 客户端根charles协商好通信密码开始通信。

step5 charles收到客户端数据用伪造证书的私钥解密

step6 charles使用同样的流程跟你的服务器建立HTTPS加密通道

step7 charles将收到的客户端数据通过建好的通道发给服务器

step8 服务器返回响应数据给charles

step9 charles解密响应数据再加密发给客户端

相关推荐
vortex52 小时前
Linux 处理以 Null 字节分隔内容的文件
linux·运维·服务器
人工智能训练2 小时前
Docker Desktop WSL 集成配置宝典:选项拆解 + 精准设置指南
linux·运维·服务器·人工智能·docker·容器·ai编程
遇见火星2 小时前
Linux 如何设置开机自启:全面指南!
linux·运维·服务器·systemd
玥轩_5213 小时前
OSPF路由协议单区域配置
服务器·网络·智能路由器·交换机·ospf·动态路由
程序猿编码3 小时前
轻量高效的HTTP/HTTPS代理:SSL拦截与流量管控核心解析
http·https·ssl·代理
小陈phd3 小时前
大语言模型实战(五)——大模型开发范式演进:从“调用API”到“多Agent复杂目标”
服务器·microsoft·语言模型
bkspiderx3 小时前
解密网络安全基石:SSL、TLS与HTTPS的前世今生
web安全·https·ssl·tls
QQ__17646198244 小时前
SSH远程时找不到模块ModuleNotFoundError
linux·服务器·ssh
CHANG_THE_WORLD4 小时前
6.2.在汇编层面,数据本身没有类型
java·服务器·汇编