PKI体系快速了解

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介: PKI体系快速了解

这是目前工作中遇到的一些知识点搜集整理。


一、什么是 PKI


首先,PKI(Public Key Infrastructure)是一个体系。


公钥基础设施是一个包括硬件、软件、人员、策略和规程的集合,用来实现基于公钥密码体制的密钥和证书的产生、管理、存储、分发和撤销等功能。

PKI体系是计算机软硬件、权威机构及应用系统的结合。它为实施电子商务、电子政务、办公自动化等提供了基本的安全服务,从而使那些彼此不认识或距离很远的用户能通过信任链安全地交流。


— 百度百科


说白了,PKI还是提供了彼此身份确认的服务,确保通信的安全。


接下来,打开百度的网址,进一步了解PKI体系中的各种角色。


1. 数字证书


我跟你对话,如果确认彼此就是自己要对话的人?那么我们可以互相亮出身份证,来证实彼此身份是可靠的。


那么,在网络通信里,也需要用到这样的介质,那就是数字证书。


点开百度网址左边的小锁图标,浏览器会显示如下,告诉你这个连接是安全的。


b8ef96f8-a3aa-4dbc-a8e8-e848246e3666.png


浏览器之所以能确认百度的身份,就是因为数字证书。点击这个按钮,进一步可以看到证书相关信息。


da447e37-0b25-4b67-aeb1-f756020d1a8f.png


信息大概可以分为 3 类:


1.1 使用者


  • 使用者的信息,如果是企业这里就是域名,示例中为baidu.com...。
  • 公钥信息,这里是非对称加密中用户公开的密钥,谁都可以看到。、
  • 有效期


1.2 颁发者


  • 颁发者:谁颁发的证书,这里的GlobalSign Organization Validation。
  • 颁发者的签名:颁发者对该证书的所有信息的数字签名,表明他对这个证书的真实性负责。


1.3 证书的其他信息


证书相关的其他信息


基于此,当浏览器访问https的网址,就会检查证书的有效性,通过后使用证书里的信息(主要是公钥)与网址进行通信。


2. 公开密钥加密(非对称加密)


数字证书的关键在于公钥,也就是非对称加密算法。它有2个角色:


  • 私有密钥 (private key):私有密钥不能让其他任何人知道。
  • 公开密钥(public key):公开密钥则可以随意发布,任何人都可以获得。
    交互过程是这样的(发送密文方A,接收方B):


  1. A 使用 B 的公开密钥进行加密。
  2. A 发送加密后的信息给 B。
  3. B 收到加密的信息后,用自己的私有钥匙进行解密。


利用这种方式,不需要发送用来解密的私有密钥,也就不必担心密钥被攻击者窃听而盗走。


另外,就算你知道了公开密钥和密文,想要恢复到信息原文是异常困难的。因为解密过程就是在对离散对数进行求值,这并非轻而易举就能办到。


再退一步讲,如果能对一个非常大的整数做到快速地因式分解,那么密码破解还是存在希望的。但就目前的技术来看是不太现实的。


f0f87101-5a6f-43df-b1b0-2e50ef603bb1.png


3. PKI登场


上面在上述的公开密钥加密方式还是存在一个问题:


  • 无法证明公开密钥本身就是货真价实的公开密钥。


比如,A 正准备和 B 服务器建立公开密钥加密方式下的通信,A 也确实收到了公开密钥。但是 A 不知道这个公开密钥是不是真的来自于 B,或许在传输途中,真的公开密钥已经被攻击者替换掉了。


所以,还需要一套机制来证明过程中的这些内容都是可靠的,这里就需要开头提到的PKI体系了,其核心是证书的产生和分发层级。


证书的产生则来自一位的重要角色:数字证书认证机构(CA,Certificate Authority)。


全世界有大概几十家左右的根CA(Certificate Authority),计算机上都会预置这些CA的数字证书。比如Amazon、Verisign这种,他们有一整套的机制保证自己是可信的。基于此,他们有自己的数字证书,及与之匹配的私钥。


网站若想拿到自己的证书,就可以找个子CA,填好信息付好年费,就可以拿到证明了。当浏览器访问网站的时候,看到你有业内权威开的证明,自己也核对没问题后就无条件信任你了。


f925c5f0-48b5-41ac-a024-7b8cc5b95323.png


在这里,PKI 体系必须为用户提供安全和透明的服务,用户不必考虑 PKI 体系中的证书是怎样生成、更新、撤销及恢复的,密钥是如何管理的,只要用户自己能够方便地获得数字签名即可。


二、PKI在汽车行业的应用


PKI体系在汽车行业的应用场景非常广泛,如远程车控、近场车控、安全启动、Ethernet通信安全等等。在此处讲一个优先级最高的“远程车控”的实例。


1. 建立自己的PKI体系


企业应该先行建立自己的PKI体系,即引入一个PKI供应商,将证书的颁发、申请、吊销等公用模块建立起来。接下来,在其之上,建立各应用的流程。


92f9bd39-5313-4775-87ea-6898fc32c06d.png


2. 各端接入PKI体系


手机端、云端与车端Tbox,都在本地生成自己的私钥,并在云端申请完自己的证书。这也需要制定相应的业务流程。


三端都需要妥善保管好自己的私钥,手机端可以将私钥存储在TEE中,云端可存储的选择会较多,车端可存储在HSM或TEE中。若没有这些硬件的存储方式,可以使用软件的白盒加密方法,安全性也有一定保障。白盒加密也就是说即使遭遇白盒攻击,其密钥也较难被破解。


3. 开始业务


大家都具备证书与私钥后,业务流程就变的相当简单了。


08370ce4-1fbd-45ea-bac7-a28a93c549a1.png


  • 云端与车端由于交互较多,建议两端通过双向认证交换“会话密钥”(对称密钥)。因为对称加密要比非对称加密要快上千倍,根据密钥长度不同会稍有变化。交换会话密钥的流程可参考TLS的双向认证的握手流程。
  • 手机端将车端指令发给云端,并使用自己的私钥进行签名。云端收到之后,使用手机A的数字证书,进行验签。
  • 云端将车控指令用协商好的“会话密钥”加密后,发送给车端。车端验证后,即可在内部执行。


所以,基于PKI体系的方案是更加可靠的。

相关文章
|
3月前
|
存储 安全 算法
公钥基础设施(PKI)的核心概念详解
【8月更文挑战第31天】
391 0
|
6月前
|
存储 安全 网络安全
什么是公钥基础设施?
【5月更文挑战第11天】什么是公钥基础设施?
128 1
|
6月前
|
安全 算法 网络安全
|
存储 安全 算法
PKI体系与CA证书
PKI体系与CA证书
310 0
|
安全 网络协议 网络安全
部署PKI 和证书服务
部署PKI 和证书服务
155 0
|
存储 安全 算法
深入理解 PKI
深入理解 PKI
447 0
深入理解 PKI
|
安全 网络协议 网络安全
部署PKI和证书服务详解
部署PKI和证书服务详解
266 0
|
SQL JavaScript 前端开发
|
安全 测试技术 云计算
RSA2009:云计算服务如何保证安全?
今年举行的RSA会议上公布的一项调查显示,使用云计算服务的企业很担心相关安全问题,但是他们并没有对供应商提供的安全性与其所承诺的安全进行对比核查。 这项由Deloitte-Ponemon研究所进行的调查表明,使用云服务的受访者中,大多数都表示他们在与服务供应商的合同中涵盖了安全要求,但是82.6%的受访者表示他们并没有对安全要求进行合规检查的计划。
772 0