C# RSA加密解密

RSA加密算法是一种非对称加密算法。在公开密钥加密和电子商业中RSA被普遍使用。RSA是1977年由罗纳德·李维斯特(Ron Rivest)、阿迪·萨莫尔(Adi Shamir)和伦纳德·阿德曼(Leonard Adleman)一块儿提出的。当时他们三人都在麻省理工学院工做。RSA就是他们三人姓氏开头字母拼在一块儿组成的。
C#使用RSA加密算法重要的一个类就是RSACryptoServiceProvider,这个类能够生成一对公钥和私钥,同时也能够加密和解密。html

生成公钥和私钥的代码以下:算法

/// <summary>
/// 生成一对公钥和私钥
/// </summary>
/// <returns></returns>
public KeyValuePair<string, string> GetKeyPair1()
{
    RSACryptoServiceProvider RSA = new RSACryptoServiceProvider();
    string public_Key = Convert.ToBase64String(RSA.ExportCspBlob(false));
    string private_Key = Convert.ToBase64String(RSA.ExportCspBlob(true));
    return new KeyValuePair<string, string>(public_Key, private_Key);
}
/// <summary>
/// 生成一对公钥和私钥
/// </summary>
/// <returns></returns>
public KeyValuePair<string, string> GetKeyPair2()
{
    RSACryptoServiceProvider RSA = new RSACryptoServiceProvider();
    string public_Key = RSA.ToXmlString(false);
    string private_Key = RSA.ToXmlString(true);
    return new KeyValuePair<string, string>(public_Key, private_Key);
}

加密方法,加密方法RSA.Encrypt,解密方法RSA.Decrypt。这个不用多说,关键是导入私钥和公钥。ide

//方法1
RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
rsa.ImportCspBlob(Convert.FromBase64String(str_Public_Key));
//方法2
RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
rsa.FromXmlString(privateKey);

 


 

RSA非对称加密,支持公钥加密私钥解密,或者私钥加密公钥解密,可是C#却只实现了公钥加密私钥解密,若是咱们须要实现私钥加密公钥解密,就须要使用到第三方插件,“BouncyCastle.Crypto”,具体操做方法以下:加密

 

原文参考了:https://www.cnblogs.com/dj258/p/6049786.htmlspa

相关文章
相关标签/搜索