RSA实现C# 加密详解

开发 后端
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的应用有所帮助。

【编辑推荐】

  1. 浅析XML序列化的优缺点
  2. 浅析C# XML编程实现添加XML文件内容
  3. C# XML编程删除XML文件内容操作详解
  4. 浅谈C# 加密中MD5和SHA1加密实现
  5. 简析散列算法在C# 加密中的应用
责任编辑:仲衡 来源: cftea.com
相关推荐

2009-09-09 18:57:26

C# 加密TripleDES

2009-08-13 18:12:11

C#数据加密

2009-08-25 18:04:30

C#实现Singlet

2009-08-31 16:23:13

C#接口

2009-08-25 17:43:17

C#串口监听

2009-08-25 10:44:50

C#实现多语言

2009-08-21 10:13:02

C#异步初步

2009-08-26 11:07:36

C#打印窗体

2009-08-26 09:22:44

C#实现打印功能

2009-08-26 11:32:37

C#打印文档

2009-08-26 12:59:08

C#打印设置

2024-04-15 10:32:14

2009-09-03 14:55:56

C#实现DataGri

2009-08-20 16:33:44

Socket异步通讯

2009-09-09 12:55:59

C# TextBox事

2009-09-07 03:44:50

C#窗体间传值

2009-09-10 16:30:11

C#排序函数

2024-10-31 11:03:06

C#椭圆运动缓冲

2012-10-31 17:37:48

2009-08-14 17:09:48

C#引用类型
点赞
收藏

51CTO技术栈公众号