博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Charles抓包原理
阅读量:4142 次
发布时间:2019-05-25

本文共 720 字,大约阅读时间需要 2 分钟。

文章目录

先说HTTPS加密过程

  • 为什么需要证书加密?
    因为对称加密不安全,非对称加密计算量又很大,影响效率,所以采用这种第一次非对称之后都是对称的加密方法

证书加密详细过程如下,参考网上一张图:

在这里插入图片描述

  1. 客户端需要数据请求的时候,首先会给服务器发送HTTPS请求
  2. 服务器响应后会将自己的证书发给客户端
  3. 客户端生成一个随机密钥,用服务器的公钥对这个密钥进行非对称加密。
  4. 将用服务器公钥加密的对称密钥发送过去
  5. 服务器用私钥进行解密
  6. 发送编码改变通知,表示随后的信息都将用双方商定的加密方法和密钥发送和服务器握手结束通知,表示服务器的握手阶段已经结束然后双方就用这个对称密钥来进行数据加密了
  7. 客户端解密后,握手结束
  8. 使用对称密钥正常通信

Charles原理

参考网上的图:

在这里插入图片描述

  1. 客户端需要请求数据时向服务器发送请求
  2. Charles中途拦截,向服务器发送请求
  3. 服务器返回证书
  4. Charles拦截,将自己的证书发给客户端
  5. 客户端解析证书取出(Charles的)公钥,然后使用公钥加密对称密钥,发送给服务器
    注意,这一切实现的前提是客户端信任Charles的证书
  6. Charles再次拦截,用私钥取出对称密钥(用于之后读取每次消息),然后用服务器的公钥加密对称密钥发送给服务器
  7. 服务器发送编码改变通知,表示随后的信息都将用双方商定的加密方法和密钥发送,服务器握手结束
  8. Charles拦截,替换成自己的证书(客户端在此次连接中一直与Charles通信(从未和服务器有过通信),所以之后的每次发送消息Charles都要将服务器的证书换成自己的)
  9. 现在的通信其实可以完全分为两个,客户端-Charles,Charles-服务器,在Charles上我们就可以看到接口数据啦

转载地址:http://qkkti.baihongyu.com/

你可能感兴趣的文章
mysql 1449 : The user specified as a definer ('root'@'%') does not exist 解决方法
查看>>
js 阻止form表单提交
查看>>
MySQL 将查询出来的一列数据拼装成一个字符串
查看>>
MySQL 存储过程或者函数中传参数实现where id in(1,2,3,...)IN条件拼接
查看>>
iOS 报错信息: dyld: Library not loaded: @rpath/XCTest.framework/XCTest Referenced framework
查看>>
分布式服务框架 Zookeeper -- 管理分布式环境中的数据
查看>>
基于Spring Boot和Spring Cloud实现微服务架构学习(一)-Spring框架介绍
查看>>
自建framework提交审核报错 ERROR ITMS-90087解决办法
查看>>
2017 年你应该学习的编程语言、框架和工具
查看>>
maven提示invalid LOC header (bad signature)的解决办法
查看>>
Ubuntu/kali上安装MySQL,设置远程访问详细教程
查看>>
Tomcat配置HTTPS及访问HTTP自动跳转到HTTPS
查看>>
Mysql错误: ERROR 1205: Lock wait timeout exceeded解决办法
查看>>
MySQL索引背后的数据结构及算法原理
查看>>
MySQL通用优化技巧
查看>>
替代mmm方案的mariadb galera cluster和percona xtradb cluster的简介
查看>>
hadoop安装之-hive
查看>>
hadoop安装之-hadoop
查看>>
hadoop安装之-hbase
查看>>
Mysql自动化安装
查看>>