数字证书:签名证书&加密证书

本文介绍了数字证书的基础概念,包括数字签名和数字证书的作用原理。重点阐述了加密证书和签名证书的区别与应用,以及在国内双证书体系下这两种证书如何提高信息安全。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先介绍一下基础技术铺垫

数字证书是基于认证机构(可信第三方)实现的,若不懂请复习PKI相关知识,我国为了加强对数据机密性的管控,采用双证书体系(签名证书&加密证书),签名密钥对由用户自己产生,而加密密钥对则是由KMC(密钥管理中心)生成。
——————————————————————————————————————————

这里可以复习一下数字签名和数字证书的知识

数字签名是为了实现不可否认性或者叫抗抵赖性的一种技术,是使用自己的私钥进行签名,验证方用发送方的公钥对其进行验证,来确认发送方的身份。
但这个过程存在一定问题,这个公钥怎么确定是发送方的呢?存在中间人攻击的问题。
那么数字证书的出现,就解决了这个问题,数字证书是基于认证机构(可信第三方)进行认证,也就是PKI体系,前提是这个第三方是可信的,第三方也有一对公私钥,用其私钥对发起认证方的基本信息及公钥进行签名,上述的验证方就可以使用认证机构的公钥进行验证,来确定这个发送方公钥来源的真实性。

进入正题:什么是加密证书和签名证书?

数字证书可分为签名证书和加密证书。
签名证书主要用于对用户信息进行签名,以保证信息的有效性和不可否认性;
加密证书主要用于对用户传送信息进行加密,以保证信息的保密性和完整性。
每个证书都包含一对密钥即签名公钥和签名私钥,加密公钥和加密私钥,将签名证书和加密证书的公钥公布于外。
签名时,用签名证书的私钥进行签名,其他用户可以利用公布于外网的签名公钥对签名进行验证。
加密时,用户B利用用户A公布于外网的加密公钥对信息进行加密传送给用户A,用户A利用自己的加密私钥对加密后的信
息进行解密得到完整的明文信息。

下面是引用其它文章对国内双证书的介绍

既然单证书可以搞定一切,为何要使用双证书?
原文链接:https://blog.youkuaiyun.com/slikel/article/details/84288936

逻辑上:
如果签名私钥遗失,大不了用户再产生一对,并无多大影响,因此签名密钥没必要交给CA;

如果加密密钥遗失,别人发过来的信息我就没办法解密了,必须从CA那里获取存根。

单证书的话,如果私钥丢了,你如何恢复之前得到的信息呢?

因此从道理上来说两个密钥具有不同的属性,逻辑上应该分开处理。

安全性上:

单证书增加了用户签名被伪造的风险

国家意志:

国家要保证必要的时候有能力对某些通讯进行监控,如果采用单证书,除了自己谁也无法解密(理论上啦),不利于国家安全。因此很多国家法律规定使用双证书。

双证书签发流程:

虽然是双密钥和双证书,从流程上来看,一遍流程即可搞定。

1,用户产生签名密钥对,发送证书请求给RA/CA(请求中包含1个公钥)

2,RA/CA向KMC请求加密密钥对

3,签发两张证书,连同加密密钥一起发送给用户(采用签名证书加密)

4,用户使用自己的签名私钥解密,获得两张证书+加密密钥。

实验目的: 1. 了解加密、数字签名证书的基本概念; 2. 熟悉 OpenSSL 工具的使用; 3. 掌握 OpenSSL 工具生成证书加密、数字签名的方法。 实验环境: - 操作系统:Windows 10; - 工具软件:OpenSSL。 实验步骤: 1. 生成自签名证书 使用 OpenSSL 工具生成自签名证书的命令为: ``` openssl req -new -x509 -keyout server.key -out server.crt -days 365 ``` 这条命令将生成一个自签名证书,其中: - `-new` 表示生成一个新的证书请求; - `-x509` 表示生成自签名证书; - `-keyout` 表示生成的私钥文件名; - `-out` 表示生成的证书文件名; - `-days` 表示证书有效期天数。 2. 加密与解密 使用 OpenSSL 工具进行加密解密的命令为: ``` openssl enc -aes-256-cbc -in plaintext.txt -out ciphertext.enc -pass pass:password openssl enc -d -aes-256-cbc -in ciphertext.enc -out plaintext.txt -pass pass:password ``` 这两条命令分别表示加密解密操作,其中: - `-aes-256-cbc` 表示使用 AES-256 算法加密; - `-in` 表示输入文件名; - `-out` 表示输出文件名; - `-pass` 表示加密解密所用的密码。 3. 数字签名与验证 使用 OpenSSL 工具进行数字签名验证的命令为: ``` openssl dgst -sha256 -sign private.key -out signature.sha256 plaintext.txt openssl dgst -sha256 -verify public.key -signature signature.sha256 plaintext.txt ``` 这两条命令分别表示数字签名验证操作,其中: - `-sha256` 表示使用 SHA-256 算法签名; - `-sign` 表示使用私钥进行签名; - `-out` 表示输出签名文件名; - `-verify` 表示使用公钥进行验证; - `-signature` 表示签名文件名。 实验结果: 通过 OpenSSL 工具生成了自签名证书,并使用该证书进行加密解密操作,同时也使用 OpenSSL 工具进行了数字签名验证操作。 实验结论: OpenSSL 工具是一个功能强大的加密工具,可以方便地生成证书、进行加密、解密、数字签名验证等操作。在实际开发中,可以使用 OpenSSL 工具来保障数据的安全完整性。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值