IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> HTTPS 原理简要总结 -> 正文阅读

[网络协议]HTTPS 原理简要总结

HTTPS 的原理

最近看了下《图解 HTTP》,对 HTTPS 怎么实现安全的原理总结了一下。

HTTPS 的原理要从怎么解决安全性问题来一步步阐明,这样说起来会更清晰一点:

  1. 如何解决网络传播中数据安全问题?

答:运用对称加密或者非对称加密来加密数据内容。https 使用对称加密加密数据内容,不使用非对称加密是因为性能比对称加密更差。

  1. 对称加密的密钥需要双方都要知道,如何保证密钥安全?

答:使用非对称加密加密对称加密的密钥。客户端拥有非对称加密的公钥,对对称加密的密钥加密后,传给服务端,服务端用非对称加密的私钥解密,拿到明文的对称加密的密钥,确保对称加密的密钥在网络传输中不被劫持破解。

  1. 客户端从哪拿到非对称加密的公钥?并且怎么确保这个公钥是服务器下发的,而不是攻击人中途替换的?

答:服务端生成一对非对称加密的公私钥,公钥会给客户端。至于这个公钥的权威性如何保证,主要依赖CA认证。服务器把公钥给CA去认证,CA在确认这个申请人的身份后,会对公钥做数字签名(CA自己的私钥加密),然后这个 数字签名+明文公钥 会一并给服务端,服务端再给客户端,客户端拿CA机构的公钥去对这个数字签名进行验证(公钥验签),没问题的话就说明服务器下发的 非对称加密 的公钥是没有掉包的,值得信赖的。

  1. 客户端哪来的CA机构的公钥?

答:游览器会直接内置常用CA机构的公钥。所以至此我们也能进一步理解抓包软件的原理,在我们使用抓包软件的时候,通常需要先导入并信任抓包软件提供的证书,这样抓包软件可以伪装成为CA,客户端实际就成了在与抓包软件进行https通讯(自然也就可以解密客户端传的明文信息);然后抓包软件又与服务端进行通信,把自己伪装成客户端(自然也就可以解密服务端传的明文信息)。抓包软件能够顺利成功实施中间人攻击的关键就是用户主动内置并信任抓包软件的证书。
在这里插入图片描述

声明

  • 本章总结了《图解 HTTP》的内容,想系统学习可以直接阅读本书。
  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-02-04 11:22:00  更:2022-02-04 11:23:35 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 22:35:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码