RSA加密,解密,签的名,验签的原理及方法

  

二,RSA加密,签名区别

  

加密和签名都是为了安全性考虑,但略有不同。常有人问加密和签名是用私钥还是公钥?其实都是对加密和签名的作用有所混淆。简单的说,加密是为了防止信息被泄露,而签名是为了防止信息被篡改。这里举两个例子说明。

  

第的一个场景:战场上,我要给一个传递一条消息,内容为某一指令。

  

RSA的加密过程如下:

  

(1)生成一对密钥(公钥和私钥),私钥不公开,一个自己保留。公钥为公开的,任何人可以获取。

  

(2)传递自己的公钥给B, B用的公钥对消息进行加密。

  

(3)接收到B加密的消息,利用一个自己的私钥对消息进行解密。

  

在这个过程中,只有2次传递过程,第一次是一个传递公钥给B,第二次是B传递加密消息给,即使都被敌方截获,也没有危险性,因为只有一个的私钥才能对消息进行解密,防止了消息内容的泄露。

  

第二个场景:收到B发的消息后,需要进行回复收”到“。

  

RSA签名的过程如下:

  

(1)生成一对密钥(公钥和私钥),私钥不公开,一个自己保留。公钥为公开的,任何人可以获取。

  

(2)一个用自己的私钥对消息加签,形成签名,并将加签的消息和消息本身一起传递给b .

  

(3) B收到消息后,在获取一的公钥进行验签,如果验签出来的内容与消息本身一致,证明消息是一个回复的。

  

在这个过程中,只有2次传递过程,第一次是一个传递加签的消息和消息本身给B,第二次是B获取一的公钥,即使都被敌方截获,也没有危险性,因为只有一个的私钥才能对消息进行签名,即使知道了消息内容,也无法伪造带签名的回复给B,防止了消息内容的篡改。

  

但是,综合两个场景你会发现,第一个场景虽然被截获的消息没有泄露,但是可以利用截获的公钥,将假指令进行加密,然后传递给A第二个场景虽然截获的消息不能被篡改,但是消息的内容可以利用公钥验签来获得,并不能防止泄露。所以在实际应用中,要根据情况使用,也可以同时使用加密和签名,比如A和B都有一套自己的公钥和私钥,当一个要给B发送消息时,先用B的公钥对消息加密,再对加密的消息使用一个的私钥加签的名,达到既不泄露也不被篡改,更能保证消息的安全性。

  

总结:公钥加密,私钥解密,私钥签名,公钥验签。

RSA加密,解密,签的名,验签的原理及方法