打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
RSA实现C# 加密详解 - 51CTO.COM
    RSA实现C# 加密是怎么办到的呢?我们首先了解下RSA的概念以及它的使用,那么如何RSA实现C# 加密还是请本文给你慢慢讲述。

    RSA实现C# 加密首先我们来了解下什么是RSA ,它属于不对称加密,其原理就是使用一个公钥一个私钥,公钥可以公开用以加密,私钥严格保密用于解密,那么这样大家知道了RSA 适合于数据量不大的加密,比如加密对称加密的密钥。

    RSA实现C# 加密的过程实例:

    RSACryptoServiceProvider 的名称空间是:

            
    1. System.Security.  
    2. CryptographyRSACryptoServiceProvider   
    3. rsaSend = new RSACryptoServiceProvider();  
    4.  
    5. string plaintext = "明文"//明文  
    6.  
    7. byte[] ciphertext = rsaSend.Encrypt(  
    8. System.Text.Encoding.UTF8.GetBytes(plaintext), false);  
    9.  //加密后  
    10.  
    11. lbl.Text = Convert.ToBase64String(ciphertext);   
    12. //显示加密后的,为了显示不可见字符,使用的是 Base64 编码。  

    使用 RSACryptoServiceProvider() 创建 RSACryptoServiceProvider 实例时,自动产生密钥。

    RSA 实际应用中是:接收方产生公钥和私钥,发送方用其公钥加密,再把加密后的内容发送给接收方。

    CspParameters 的名称空间是:

            
    1. System.Security.CryptographyCspParameters cpSend =   
    2. new CspParameters(); //Csp = Cryptography Service Provider  
    3. CspParameters cpReceive = new CspParameters();  
    4. cpSend.KeyContainerName = "SendTestContainer";  
    5. cpReceive.KeyContainerName =   
    6. "ReceiveTestContainer";  
    7.  
    8. RSACryptoServiceProvider rsaSend =   
    9. new RSACryptoServiceProvider(cpSend); ;  
    10. RSACryptoServiceProvider rsaReceive =   
    11. new RSACryptoServiceProvider(cpReceive);  
    12.  
    13. rsaSend.FromXmlString(rsaReceive.ToXmlString(false));   
    14. //发送方使用接收方给它的公钥进行加密  
    15.  
    16. string plaintext =   
    17. "前几天我碰到一个朋友,约我跟马贼打架,  
    18. 我立马答应了他,因为我觉得这件事好无聊。";  
    19. byte[] ciphertext =   
    20. rsaSend.Encrypt(System.Text.Encoding.UTF8.GetBytes(  
    21. plaintext), false); //加密后  
    22. byte[] decryption =   
    23. rsaReceive.Decrypt(ciphertext, false); //解密后  
    24.  
    25. lbl.Width = 760;  
    26. lbl.Text = "";  
    27. lbl.Text +=   
    28. Convert.ToBase64String(ciphertext) + "﹤br /﹥";   
    29. //显示加密后的  
    30. lbl.Text +=   
    31. System.Text.Encoding.UTF8.GetString(decryption) + "﹤br /﹥";   
    32. //显示解密后的  
    33. lbl.Text +=   
    34. Server.HtmlEncode(rsaSend.ToXmlString(false)) + "﹤br /﹥";  
    35.  //显示发送方公钥  
    36. lbl.Text +=   
    37. Server.HtmlEncode(rsaReceive.ToXmlString(true)) + "﹤br /﹥";   
    38. //显示接收方公钥和私钥  
    39. lbl.Text +=   
    40. Server.HtmlEncode(rsaReceive.ToXmlString(false)) + "﹤br /﹥";   
    41.  //显示接收方公钥  
    42.  
    43. rsaSend.PersistKeyInCsp = true//密钥要保存起来  
    44. //rsaSend.Clear();  
    45. rsaReceive.PersistKeyInCsp = true;  
    46. //rsaReceive.Clear();  

    在上面的代码中,我们使用 CspParameters 将密钥保存起来,ToXmlString 和 FromXmlString 将接收方的公钥告诉给发送方。

    RSA实现C# 加密的实际操作就向你介绍到这里,希望对你了解和学习C# 加密以及RSA的应用有所帮助。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
.NET中非对称加密RSA算法的密钥保存
C#中RSA加密解密和签名与验证的实现
使用X.509数字证书加密解密实务(三)-- 使用RSA证书结合对称加密技术加密长数据
用RSA加密实现Web登录密码加密传输
最通俗易懂的RSA加密解密指导
net加密基础2
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服