X.509证书认证模式简介
1 非对称密码学(Asymmetric Cryptography)
站在消息交换的角度,密码学就是帮助我们实现对整个消息或者对消息的某个部分进行数字签名和加密
的理论和方法
数字签名和加密依赖于相应的加密算法(Cryptographic Algorithm)
从数学的角度来讲,加密算法是就是将被加密的数据和密钥作为自变量,将加密后的数据作为因变量的函数
与加密相对的操作是解密
按照加密和解密采用的密钥是否相同,我们将加密算法分为
-
对称加密算法
采用相同的密钥进行加密和解密 -
非对称加密算法
采用一组相互配对的密钥分别进行加密和解密。
对于非对称加密,我们选择密钥对中某一个密钥对消息进行加密,该密文只有通过另一个密钥方能解密
非对称密码学具有两个主要的应用
- 直接通过对消息进行加密解决机密性问题
- 通过数字签名实现身份认证和数据一致性的问题
1.1 消息加密(Encryption)
非对称加密依赖一组由公钥/私钥(Public Key /Private Key)组成的密钥对,所以采用非对称加密又被称为公钥加密(Public Key Cryptography)
公钥和私钥均可以用于加密。如果密钥对中的其中一个用于加密,另一个则用于解密
- 公钥公诸于众,不具有隐私性,任何人均可以获取
- 私钥专属于拥有该密钥对的实体,属于绝对隐私
对于消息交换来说,通过非对称的方式对消息进行加密能够确保消息的机密性
- 具体的做法
消息发送方采用接收方的公钥进行加密,接收方通过自己的私钥进行解密
私钥仅供接收方所有
,所有其他人不能对密文进行解密
1.2 数字签名(Digital Signature)
包括两项主要的工作,签名(Signing)和检验(Verification),前者创建一个数字签名,后者验证签名的有效性
签名的过程
- 首先,发送方首先采用某种算法对整个消息的内容实施哈希计算,得到一个哈希码
- 然后,发送方使用自己的私钥对该哈希码就行加密,加密后得到的密文就是数字签名
该数字签名最终会连同发送方密钥对中的公钥(一般会内嵌在一个数字证书中)附加到原消息上一并发给接收方
这三项被接收方接收后,它就可以借助这个数字签名验证发送方的真实身份和消息的完整性,这个过程被称为数字签名的验证
- 首先,原消息被提取出来,通过相同的哈希算法得到一个哈希码
- 然后,数字签名被提取出来,采用相同的算法利用公钥对数字签名进行解密,得到生成数字签名的那个哈希码。两个哈希码进行比较,如果一致则可以证明数字签名的有效性以及消息本身的完整性。
采用非对称密码学对消息加密解决的是消息的机密性问题
数字签名的作用
身份认证(Authentication)
数字证书可以帮助我们验证消息发送源的真实身份
,因为数字签名的内容是由一个私钥决定的,发送方只有通过专属于它的密钥对中的私钥生成数字签名,采用通过对方利用公钥实施的数字签名检验
私钥是属于拥有者的私密信息,不对外公开。对数字证书的检验实际上就是确认消息的发送源是否是私钥的真正拥有者
防止抵赖(Non-repudiation)
防止抵赖在这里的代表对于接收到的经过数字签名的消息
如果接收方采用某个实体的公钥对数字签名检验成功,那么这个实体就是消息的发送方,不容对方抵赖
因为能够通过公钥对某个数字签名成功检验,就证明生成该数字签名使用的是正确的私钥
消息一致性(Integrity)
最初被用于私钥加密的哈希码是针对整个消息的内容进行哈希计算获得的。消息的内容一旦出现任何的改变,最终对数字签名的检验都将失败。
在上面介绍数字签名的流程时,我们说发送方的公钥会连同生成的数字签名会附加到消息中,一并传送给接收方,以辅助接收方对发送进行身份验证
实际上,这个公钥在一般情况下是通过数字证书的形式进行传递的。数字证实在这里作为发送方的凭证,现在我们就来简单介绍一下数字证书。
2 数字证书
证书,又称数字证书(Digital Certificate)或者公钥证书(Public Key Certificate),一种数字签名的声明,它将公钥的值绑定到持有对应私钥的个人、设备或服务的标识
由于大多数普通用途的证书基于 X.509 V3 证书标准,所以我们又将其称为X.509证书
X.509证书广泛地被应用于加密(Encryption)和数字签名(Digital Signature),以提供
认证的实现和确保数据的一致性(Integrity)和机密性(Confidentiality)
下面的代码片断体现了一个X.509证书的大体结构
- 公钥(00:b4:31:98:... 52:7e:41:8f)
- 公钥算法(rsaEncryption)
- 颁发者的数字签名(93:5f:8f:5f:... b5:22:68:9f)
2.1 数字证书的颁发机制
数字证书在大部分场景中是作为证明某个实体身份的凭证
被使用,而证书的主题部分的内容代表了该用户凭证所代表的身份
那么我们的第一个问题是,我们为什么要信任这个证书?
比如居民身份证就是一种典型的证书,它的一个重要的特征就是该证书是由官方认可的合法机构颁发,一般情况下身份证的办理机构就是户口所在地的公安机关
对于数字证书,尤其是用于商业用途的数字证书,也具有相应的官方办法机构,我们将这样的机构称之为认证权威机构(CA:Certification Authority)
我们熟悉的CA包括VeriSign、Thawte(OpenSSL)等
证书的颁发机构体系是一个树形结构,每一个CA可以具有一到多个子CA,最上层的CA被称为根CA。
在日常生活中,人们对居民身份证的普遍认可来源于对颁发机构,即户口所在地的公安机关的信任。这种基于对颁发机构认可的方式同样适合对数字证书。在一般情况下,认证方通过检验数字证书的CA的信任程度而作出对证书合法性的判断。
不过,现在的问题是:居民身份证具有若干防伪标识帮助认证方鉴别真伪,对于数字证书来说,我们采用怎样的方式来判断它是不是伪造的呢?验证数字证书的有效性,需要防止以下两种情况:
- 用户伪造一个证书以假冒与证书公钥绑定的那个身份,并且该证书具有一个我们普遍认可的CA
- 用户对CA颁发的证书进行篡改,改变公钥或者其他身份信息
这两个问题都可以通过数字签名技术来解决
从上面给出的数字证书我们知道,证书中不仅仅包括CA的基本信息,还包括一个数字签名和签名采用的算法
CA通过自己的私钥对证书的数据部分进行签名,并将此签名连同签名采用的算法置于证书之中
如果我们具有CA的公钥,我们不仅仅可以验证证书的CA,也能校验证书的内容是否被篡改。那么在对证书进行验证的时候,CA的公钥从何而来呢?
实际上,CA的公钥也保存在一个数字证书之中,并被存储于一个受信任的证书存储之中
按照证书代表身份的不同,我们可以将其分为两种类型
- CA证书(CA Certificate)
代表CA - 终端实体证书(End Entity Certificate)
代表接受CA证书的最终实体
实际上,CA证书和终端实体证书并没有本质的区别。除了最顶层的根CA,所有的CA证书颁发者是它的上一级CA,即上级的CA作为该CA证书的CA。CA的这种层级关系组成了一种信任链(Trust Chain)
在若干证书存储区中,有一个被称为“受信任的根证书颁发机构”(Trusted Root Certification Authorities)的存储区,它里面存储的所有CA证书代表所信任的证书颁发机构。在默认情况下,对于一个待验证的证书,如果基于该证书CA信任链上的任何一个CA在该存储区中存在一个证书,那么这个证书是合法的。
3 通过凭证三个属性来分析X.509证书
采用用户凭证的三个属性来分析数字证书。
- 凭证与申明的一致性:证书的申明反映在于公钥绑定的于主题相关的信息
- 持有人对凭证的拥有性:在绝大部分的认证过程中,都需要被认证方提供的数字证书具有相应的私钥。私钥的私有性在某种程度上证明了数字证书持有者就是该证书的拥有者
- 证书的合法性:这可以通过颁发者对证书的数字签名来验证
如果被认证方通过一个数字证书作为用户凭证,认证方一般采用信任链(Trust Chain)模式对其实施认证。在该模式下,认证方从数字证书的直接颁发机构向上追溯,如果具有任何一个颁发机构是受信任的,那么认证成功。不过,有时我们还是会采用其他的认证模式,比如严格比较证书主题信息甚至是序列号。
对于WCF来说,不仅仅客户端可以将数字证书作为证明自己身份的凭证,提供给服务端对自己进行认证。也可以将服务和某个数字证书绑定起来,通过证书代表服务的身份,供客户端进行验证。总之,数字证书在WCF中具有十分广泛的应用。