公钥和私钥的个人理解

现在HTTPS的加密通信方式:

1.通信双方各自持有自己的:公钥+私钥

2.通信双方通信时,交换公钥,保留自己私钥。

3.公钥和私钥是配对的、但是不是对称的一对钥匙。即:就算你知道公钥长什么样子,你也几乎不可能知道私钥长什么样子

          举个例子:老婆和我(假设我有老婆,哈哈哈~)约定:"老公,我好爱你哟" 代表 "老公帮我清空购物车车车车车车"。

          1.这里,我的公钥就是"老公,我好爱你哟",我老婆可以在任何人面前,可以说给我听,表现她很爱我的亚子。

          2.其实,持有私钥的我,只有我知道这句话的真实含义 ,"老公帮我清空购物车车车车车车"。

          3.万一哪天被人知道私钥了呢?几乎不可能,中国文字何止千万,别说谁能知道我在后面加了6个车,连前面的几个汉字也

             不太可能被解析。

4.公钥加密时,自我不可逆向解密,即:公钥加密不可以自我解密,只能通过私钥解密。

注意:公钥和私钥的配对方式,是有固定算法的,小弟没有研究过。

考虑一个问题,公钥加密的密文信息,用公钥本身可以解密这个密文信息吗?

1.如果你得出公钥能解密公钥自己加密的信息,那就错了,公钥是任何人都可以看见的,公钥自己如果能解密自己加密的东西,还加密做什么?

2.如果你得出公钥不能解密公钥自己加密的信息,正确的。公钥加密后,公钥自己不能解密自己加密的东西,即:公钥不能自我逆向解密。这样才能保证秘钥持有者,是唯一一个可以打开公钥密文的对象。

再考虑一个问题,公钥可以解密私钥加密的密文吗?

可以,私钥加密的密文,公钥可以对其解密。

1.HTTPS中,服务器会有公钥证书,服务器公钥证书 = 认证机构的数字签名 + 服务器公钥。

2.认证机构的数字签名,就是认证机构用认证机构的私钥加密后的数字签名。

3.认证机构会把数字签名部署到服务器上,再加上服务器的公钥,生成服务器的公钥证书。

4.浏览器是默认植入了认证机构的公钥证书的,所以,浏览器要验证服务器公钥证书的真实性,只需要用认证机构的公钥解密服务器公钥证书上的数字签名,就能验证真实性了。验证后,开始和服务器通信。这里验证就是公钥解密私钥密文的典例。

最后考虑个问题,服务器传输时,会用自己的私钥加密密文吗?

1.不会的,公钥是公开的,私钥加密密文,公钥随时可以对密文解密,用私钥加密等于没有加密,就像数字签名一样,但是数字签名是为了验证手里的服务器公钥证书是不是真实的,才会用私钥加密数字签名来发布服务器公钥证书。

2.所以,服务器会用客户端的公钥,对密文加密,让客户端用客户端自己的私钥解密。

3.同理,客户端会用服务器的公钥,对密文加密,让服务器用服务器自己的私钥解密。

 

最后,上面所提到的几个名词,有兴趣可以自己研究:公钥证书,认证机构,认证机构用认证机构的私钥部署数字签名,公私钥算法(RSA)。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 公钥可搜索加密是一种保护隐私的加密技术,可以在不暴露明文的情况下,对加密数据进行搜索和匹配。实现公钥可搜索加密的代码需要使用一些加密算法和数据结构,如RSA加密算法、Bloom Filter等。具体实现方法可以参考相关的论文和开源代码。 ### 回答2: 公钥可搜索加密(Public Key Searchable Encryption)是一种安全的加密方案,它可以在保证数据安全的同时,允许用户在加密数据中进行搜索操作。 实现公钥可搜索加密的代码需要考虑以下几个方面。 首先,需要使用公钥加密算法,如RSA或椭圆曲线加密算法,生成公钥私钥对。公钥用于加密搜索关键字,私钥用于解密搜索结果。 其次,需要考虑如何将搜索关键字加密后存储在数据库中。可以使用加密哈希函数对搜索关键字进行加密,并将其与其他数据一起存储。加密哈希函数将关键字映射为固定长度的密文,保证了数据的安全性。 然后,需要实现一个搜索功能,使用户可以输入搜索关键字,并根据关键字对加密数据进行搜索。在搜索功能中,用户输入的搜索关键字需要先使用公钥加密算法加密,然后与数据库中存储的加密关键字进行匹配。匹配成功后,使用私钥解密搜索结果,返回解密后的数据。 最后,需要考虑数据的访问控制。只有拥有私钥的用户才能解密搜索结果,其他人无法获取明文数据。因此,代码中需要实现访问控制机制,确保数据的安全性。 总结来说,公钥可搜索加密的实现代码主要包括公钥加密算法的生成、搜索关键字的加密和存储、搜索功能的实现、搜索结果的解密以及数据的访问控制。这些代码的实现可以保证数据的安全性,并允许用户在加密数据中进行搜索操作。 ### 回答3: 公钥可搜索加密(Public Key Encryption with Keyword Search, PEKS)是一种能够实现关键字搜索的加密算法。在传统的公钥加密算法中,加密解密是基于公钥私钥的,只能通过私钥来进行解密操作。但是,当我们需要在大量加密数据中搜索包含特定关键字的文件时,传统的公钥加密算法就显得不太适用了。 公钥可搜索加密算法通过引入一个陷门(trapdoor)的概念,能够实现在加密状态下进行关键字搜索。陷门是由用户的私钥生成的,用于加密指定的关键字。通过陷门,用户可以在不暴露私钥的情况下,在加密的数据集合中查询包含特定关键字的文件。 实现公钥可搜索加密的代码通常由以下几个步骤组成: 1. 密钥生成:生成公钥私钥对,公钥用于加密私钥用于生成陷门。 2. 数据加密:将需要进行搜索的数据进行加密,并存储到云服务器或其他数据存储设备中。 3. 陷门生成:用户通过私钥生成陷门,将需要搜索的关键字加密成陷门的形式。 4. 关键字搜索:用户将生成的陷门发送到云服务器上,云服务器根据陷门与加密数据进行匹配,找出含有关键字的加密文件,并将其返回给用户。 需要注意的是,公钥可搜索加密算法并不直接泄露私钥,因此仍然能够保证用户的数据安全性。同时,为了提高搜索效率,通常会引入一些优化算法,例如倒排索引等。 公钥可搜索加密代码的实现需要理解公钥加密算法的基本原理,并结合关键字搜索的需求进行具体设计。近年来,该算法已经被广泛应用于云计算和数据隐私保护等领域,为数据安全和高效搜索提供了解决方案。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值