当前位置: 首页 > article >正文

HTTPS__CA证书与签名

目录

  • 1. 数字签名
  • 2. CA证书
  • 3. 非对称加密 + 对称加密 + 证书认证
  • 4. 常见问题或其它
  • 5. 总结

1. 数字签名

  • 对一个数字摘要做加密,即数字签名。
    在这里插入图片描述

  • 签名流程:

    先把一段数据通过散列函数(摘要算法) 形成散列值(数据摘要)。

    接着使用签名者的私钥来加密散列值。(签名者也持有属于自己的公钥Q 和 私钥 Q’')

    之后将数据和已经加密了的散列值(即签名) 拼接起来,形成数字签名的数据。

  • 经过数字签名的数据,即可以验证原本的数据有没有被篡改:

    先对原始数据使用相同的散列函数,形成散列值。

    将加密后的签名,使用签名者的公钥进行解密,形成解密后的散列值。

    然后进行对比,如过二者相等,则证明原始数据没有被修改过,反之被篡改。

  • 数字签名与普通加密不同的是,即便签名过程中,数据被篡改了,连同签名被替换为中间人自己的私钥。但是用户在验证时,只认可签名者的公钥,而公钥 Q 都是内置在客户端内。而私钥 Q’’ 只有签名者拥有,也就意味着只有签名有签名的能力。

2. CA证书

  • HTTPS 回归上篇文章,采用多种方案(非对称加密 + 对称加密),最终还是无法保证安全问题,而这一切都是因为客户端无法甄别自己收到的公钥是否是合法的,因此我们就必须围绕这个问题展开去探索解决方案。

    实际上,客户端向服务器发起请求后,服务器响应给客户端的内容不仅仅只有公钥,还有 “证书”。证书的诸多字段如下图所示:
    在这里插入图片描述
    而为了防止中间人篡改证书中的公钥,同时也对这份证书携带了签名,即对整份证书的明文数据先做hash散列,形成数据摘要,然后再使用签名者的私钥进行加密,最后将签名附加在证书中。

  • 证书从哪来?谁给的?

    一家企业内部产品,如果想使用 HTTPS 协议,那么其负责人需要先向CA机构申请证书,审核完毕后给申请者颁发有效期限的证书,之后将申请到的证书内置到 HTTPS 的服务端。

    当客户端向服务端发起请求时,需要向客户端响应返回证书,以表请求的合法性。

    流程图如下:
    在这里插入图片描述

    需要注意的是,申请认证时提交的公钥,即后续返回给客户端的公钥;而客户端收到证书后,直接从证书中提取公钥,那么只要证书是合法的,提取出来的公钥即合法;所有的浏览器(客户端),一般都要内置可信的CA机构或者授权的子机构的公钥,方便用户根据CA机构的公钥验证数据的合法性。

3. 非对称加密 + 对称加密 + 证书认证

在这里插入图片描述

  • 对于这种方案,中间人同样有能力截获第一次请求响应的证书。但是 ta 无法对证书中的公钥进行篡改,因为如果篡改,客户端通过CA机构的公钥验证即可发现数据被篡改,进而终止通信,而这的本质即:用户不认可除了CA机构以外的其它公钥。而中间人也无法在篡改完证书明文后,进行二次签名,因为只有CA机构拥有签名所需的私钥。

    即便中间人也去CA机构申请一份真的证书,但是证书明文中包含了域名等服务端认证信息,而域名是具有唯一性的,当用户在验证证书的同时,也可以通过观察证书记录的域名,与自己访问的域名是否一致来判断证书的真假。因此该方案同样行不通。

    因此,无论是明文、签名,中间人都不具备篡改能力,也不具备替换证书的能力。

4. 常见问题或其它

  • 为什么摘要内容在网络传输的时候一定要加密形成签名?

    常见的摘要算法有:MD5 和 SHA 系列。

    以 MD5 为例,不研究具体计算签名的过程,只了解 MD5 的特点:

    • 定长:无论多长的字符串,计算出来的 MD5 值都是固定长度(16字节版本或者32字节版本)。
    • 分散:源字符串只要改变一点点,最终得到的 MD5 值都会差别很大。
    • 不可逆:通过源字符串生成 MD5 很容易,但是通过 MD5 还原成原串理论上是不可能的。
  • 为什么签名不直接加密,而是要先hash形成摘要?

    缩小签名密文的长度,加快数字签名的验证签名的运算速度。

  • 查看浏览器的受信任证书发布机构(以Edge为例)

    在设置中直接查找证书

    在这里插入图片描述 在这里插入图片描述

5. 总结

  • HTTPS 工作过程中涉及到的密钥有三组:

    • 第一组(非对称加密):用于校验证书是否被篡改。服务器持有私钥(私钥在形成CSR文件与申请证书时获得),客户端持有公钥(操作系统包含了可信任的 CA 认证机构有哪些,同时持有对应的公钥)。服务器在客户端请求时,返回携带签名的证书。客户端通过这个公钥进行证书验证,保证证书的合法性,进一步保证证书中携带的服务端公钥权威性。

    • 第二组(非对称加密):用于协商生成对称加密的密钥,客户端用收到的CA证书中的公钥(是可被信任的) 给随机生成的对称加密的密钥加密,传输给服务器,服务器通过私钥解密获取到对称加密密钥。

    • 第三组(对称加密):客户端和服务器后续传输的数据都通过这个对称密钥加密解密。

    一切的关键都是围绕这个对称加密的密钥,其他的机制都是辅助这个密钥工作的。

    第二组非对称加密的密钥是为了让客户端把这个对称密钥传给服务器,第一组非对称加密的密钥是为了让客户端拿到第二组非对称加密的公钥。


http://www.kler.cn/a/461439.html

相关文章:

  • C语言——字符函数和内存函数
  • React 数据是怎样传递的
  • 【服务器】上传文件到服务器并训练深度学习模型下载服务器文件到本地教程
  • vue cli更新遇到的问题(vue -V查询版本号不变的问题)
  • sqlalchemy-access库操作MS Access
  • Leetcode 3405. Count the Number of Arrays with K Matching Adjacent Elements
  • DDD(一)—— Authentication with JWT
  • 【taro react】 ---- 实现计算多个数组的笛卡尔积和对应笛卡尔积的逆解析
  • 常见的中间件漏洞
  • vue3 Teleport瞬移组件
  • win10 安装 docker desktop
  • C# OpenCV机器视觉:凸包检测
  • git在idea中操作频繁出现让输入token或用户密码,可以使用凭证助手(使用git命令时输入的用户密码即可) use credential helper
  • PyTorch快速入门教程【小土堆】之利用GPU训练
  • 渗透学习笔记(十)PowerShell基础
  • PTA数据结构作业二
  • 绑定函数来动态地确定field(组件的属性)的值,也就是对于列的展示进行处理
  • 【如何安全删除Windows和Windows.old备份文件夹】
  • Python中的sqlite3模块:SQLite数据库接口详解
  • vscode【实用教程】(2025最新版)
  • 深入理解Redis:从理论到实践的Java之旅
  • docker-开源nocodb,使用已有数据库
  • 目标检测,语义分割标注工具--labelimg labelme
  • Postman测试big-event
  • 最小特权的例子
  • 【数据仓库】hive on Tez配置