RSA实现C# 加密详解

转载 2011年01月22日 18:12:00

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 的名称空间是:

13. System.Security.CryptographyCspParameters cpSend =   

14. new  CspParameters();  //Csp = Cryptography Service Provider  

15. CspParameters cpReceive =  new  CspParameters();  

16. cpSend.KeyContainerName =  "SendTestContainer" ;  

17. cpReceive.KeyContainerName =   

18. "ReceiveTestContainer" ;  

19.  

20. RSACryptoServiceProvider rsaSend =   

21. new  RSACryptoServiceProvider(cpSend); ;  

22. RSACryptoServiceProvider rsaReceive =   

23. new  RSACryptoServiceProvider(cpReceive);  

24.  

25. rsaSend.FromXmlString(rsaReceive.ToXmlString( false ));   

26. // 发送方使用接收方给它的公钥进行加密  

27.  

28. string  plaintext =   

29. " 前几天我碰到一个朋友,约我跟马贼打架,  

30. 我立马答应了他,因为我觉得这件事好无聊。 ";  

31. byte [] ciphertext =   

32. rsaSend.Encrypt(System.Text.Encoding.UTF8.GetBytes(  

33. plaintext),  false );  // 加密后  

34. byte [] decryption =   

35. rsaReceive.Decrypt(ciphertext,  false );  // 解密后  

36.  

37. lbl.Width = 760;  

38. lbl.Text =  "" ;  

39. lbl.Text +=   

40. Convert.ToBase64String(ciphertext) +  " br / " ;   

41. // 显示加密后的  

42. lbl.Text +=   

43. System.Text.Encoding.UTF8.GetString(decryption) +  " br / " ;   

44. // 显示解密后的  

45. lbl.Text +=   

46. Server.HtmlEncode(rsaSend.ToXmlString( false )) +  " br / " ;  

47.   // 显示发送方公钥  

48. lbl.Text +=   

49. Server.HtmlEncode(rsaReceive.ToXmlString( true )) +  " br / " ;   

50. // 显示接收方公钥和私钥  

51. lbl.Text +=   

52. Server.HtmlEncode(rsaReceive.ToXmlString( false )) +  " br / " ;   

53.   // 显示接收方公钥  

54.  

55. rsaSend.PersistKeyInCsp =  true // 密钥要保存起来  

56. //rsaSend.Clear();  

57. rsaReceive.PersistKeyInCsp =  true ;  

58. //rsaReceive.Clear();  

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

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

相关文章推荐

RSA文件加密算法C#实现

  • 2012年11月02日 10:27
  • 2.44MB
  • 下载

非对称加密RSA的应用及在C#中的实现

一说到数据的加密,常常会涉及到这几个单词:算法、原文、密文和密钥。通常,发送者把原文通过一个加密的算法,用密钥进行加密后将密文发送给接收者,然后接收者再用密钥对密文进行解密,得到原文。由于常用的加密算...

C#中RSA加密解密和签名与验证的实现

RSA加密算法是一种非对称加密算法。在公钥加密标准和电子商业中RSA被广泛使用。RSA是1977年由罗纳德•李维斯特(Ron Rivest)、阿迪•萨莫尔(Adi Shamir)和伦纳德•阿德曼(Le...
  • wnety
  • wnety
  • 2011年06月29日 13:39
  • 353

C#实现RSA加密解密源码

RSA加密解密源码: using System; using System.Collections.Generic; using System.Linq; using System.Text;...

C#实现RSA加密与解密、签名与认证

一、RSA简介 RSA公钥加密算法是1977年由Ron Rivest、Adi Shamirh和LenAdleman在(美国麻省理工学院)开发的。RSA取名来自开发他们三者的名字。RSA是目前最有影响...

c#实现RSA加密解密 - - 博客频道 - zyloveyrf jinghuazhi.com

RSA公钥加密算法是1977年由Ron Rivest、Adi Shamirh和LenAdleman在(美国麻省理工学院)开发的。RSA取名来自开发他们三者的名字。RSA是目前最有影响力的公钥加密算法,...

rsa 矩阵置换 及Vernam加密算法 C#实现

刚刚搞完密码安全的课程结束论文,des算法搞了好久没搞成,就搞了rsa 矩阵置换 及Vernam加密,上代码 using System; using System.Collections....

基于私钥加密公钥解密的RSA算法C#实现

RSA算法是第一个能同时用于加密和数字签名的算法,也易于理解和操作。 RSA是被研究得最广泛的公钥算法,从提出到现在已近二十年,经历了各种攻击的考验,逐渐为人们接受,普遍认为是目前最优秀的公钥方案之一...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:RSA实现C# 加密详解
举报原因:
原因补充:

(最多只允许输入30个字)