公钥、私钥相关概念

1.    公开的密钥称为公钥,只有自己知道的称为私钥。公钥与私钥是通过一种算法生成的,是成对出现且具有唯一性,公钥是公开的部分,而私钥是保密的一部分。如果用公钥来加密必须用配对儿的私钥来解密,反之亦然。

2.    公钥通常用来加密。然后用私钥解密

应用1:保护自己的数据。Curry有公钥A和私钥B,要保护加密自己的数据不被别人窃取,他用公钥A加密,虽然公钥A大家都可以知道,但是不知道跟A配对儿的私钥B,即使被截获,在不知道B的情况下是无法解密的。所有,只有Curry自己能够解密。

应用2:加密明文。Curry有公钥A和私钥B,Alen知道Curry的公钥A,要给Curry发送信息,他用公钥A对明文进行加密,这时只有Curry用自己的私钥B才能解密,其他人即使截获,在不知道B的情况才是无法解密的。保证了数据的机密性,不保证数据的完整性、身份验证和不可否认性。

3.    私钥通常用来加密数字签名,然后用公钥验证

应用: Curry向Alen回信息

步骤1:明文经过哈希算法,转换成摘要digest。

步骤2:使用私钥B对digest进行加密得到数字签名signature

步骤3:将明文和数字签名signature一起发送至Alen

步骤4:Alen使用公钥A对数字签名signature进行解密,得到摘要digest。如果解密成功,证明信息是由Curry发送的。但是进行了身份验证,并不知道信息是否被修改。

步骤5:Alen使用哈希算法对信息进行处理,得到摘要digest2,如果此摘要与digest相同,证明信息在传输过程中没有被修改。

那么问题来了!!!!!!如果在传输过程中,信息被Peter截获,由于Curry的公钥A是公开的,Peter就将信息公钥A改为自己的公钥M,然后用自己的公钥N伪造新的数字签名向Alen发送,这时Alen其实使用的是公钥M,这样信息就被解密了,信息就会泄露。解决方法

步骤6:Alen要求Curry到证书中心CA对公钥A做认证,CA是可信任的第三方机构。CA使用自己的私钥X对Curry的公钥A和一些信息进行加密,做成数字证书Digital Certificate。

步骤7:以后Curry在回信时可以附上数字证书,Alen可以用CA的公钥进行解密,得到Curry的公钥A,然后再对信息进行解密。证明了数字签名确实是Curry

4.    数字证书

最简单的数字证书包含:公开密钥、名称和授权机构的数字签名,此外,数字证书是有时间限制的

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值