数据公钥加密和认证中的私钥公钥

本文转载
 
先前我曾经写了一篇“ 网站的安全登陆认证设计”,多是讲述的不够清楚,有一位读者就留言质疑到,“公钥顾名思义就是公开的啦,只要你愿意,谁都会有你的公钥,何来安全?应该是用网站的公钥加密,传到网站后,网站用本身的私钥解密吧”。
  这些密码学的概念容易被搞混淆,的确也情有可原。由于公钥、私钥、加密、认证这些都是较为复杂的问题,其概念不太容易理解,理解不透就容易产生各类似是而非的概念,为了让你们对于密码学有进一步的了解,这里我就详细解说一下公钥和私钥的具体做用和使用方法。

  加密和认证

  首先咱们须要区分加密和认证这两个基本概念。
  加密是将数据资料加密,使得非法用户即便取得加密过的资料,也没法获取正确的资料内容,因此数据加密能够保护数据,防止监听***。其重点在于数据的安全性。身份认证是用来判断某个身份的真实性,确认身份后,系统才能够依不一样的身份给予不一样的权限。其重点在于用户的真实性。二者的侧重点是不一样的。

  公钥和私钥

  其次咱们还要了解公钥和私钥的概念和做用。
  在现代密码体制中加密和解密是采用不一样的密钥(公开密钥),也就是非对称密钥密码系统,每一个通讯方均须要两个密钥,即公钥和私钥,这两把密钥能够互为加解密。公钥是公开的,不须要保密,而私钥是由我的本身持有,而且必须妥善保管和注意保密。
  公钥私钥的原则:
  1. 一个公钥对应一个私钥。
  2. 密钥对中,让你们都知道的是公钥,不告诉你们,只有本身知道的,是私钥。
  3. 若是用其中一个密钥加密数据,则只有对应的那个密钥才能够解密。
  4. 若是用其中一个密钥能够进行解密数据,则该数据必然是对应的那个密钥进行的加密。
  非对称密钥密码的主要应用就是公钥加密和公钥认证,而公钥加密的过程和公钥认证的过程是不同的,下面我就详细讲解一下二者的区别。

  基于公开密钥的加密过程

  好比有两个用户Alice和Bob,Alice想把一段明文经过双钥加密的技术发送给Bob,Bob有一对公钥和私钥,那么加密解密的过程以下:
  1. Bob将他的公开密钥传送给Alice。
  2. Alice用Bob的公开密钥加密她的消息,而后传送给Bob。
  3. Bob用他的私人密钥解密Alice的消息。
  上面的过程能够用下图表示,Alice使用Bob的公钥进行加密,Bob用本身的私钥进行解密。

  基于公开密钥的认证过程

  身份认证和加密就不一样了,主要用户鉴别用户的真伪。这里咱们只要可以鉴别一个用户的私钥是正确的,就能够鉴别这个用户的真伪。
  仍是Alice和Bob这两个用户,Alice想让Bob知道本身是真实的Alice,而不是假冒的,所以Alice只要使用公钥密码学对文件签名发送给Bob,Bob使用Alice的公钥对文件进行解密,若是能够解密成功,则证实Alice的私钥是正确的,于是就完成了对Alice的身份鉴别。整个身份认证的过程以下:
  1. Alice用她的私人密钥对文件加密,从而对文件签名。
  2. Alice将签名的文件传送给Bob。
  3. Bob用Alice的公钥解密文件,从而验证签名。
  上面的过程能够用下图表示,Alice使用本身的私钥加密,Bob用Alice的公钥进行解密。

  总结

  好了,上面就详细讲述了加密、认证、公钥、私钥这四个概念,明白这些概念后,你就应该对“ 网站的安全登陆认证设计”一文所讲述的概念有了更清晰的了解了。