自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

RSA實(shí)現(xiàn)C# 加密詳解

開(kāi)發(fā) 后端
RSA實(shí)現(xiàn)C# 加密是怎么辦到的呢?我們首先了解下RSA的概念以及它的使用,那么如何RSA實(shí)現(xiàn)C# 加密還是請(qǐng)本文給你慢慢講述。

RSA實(shí)現(xiàn)C# 加密首先我們來(lái)了解下什么是RSA ,它屬于不對(duì)稱(chēng)加密,其原理就是使用一個(gè)公鑰一個(gè)私鑰,公鑰可以公開(kāi)用以加密,私鑰嚴(yán)格保密用于解密,那么這樣大家知道了RSA 適合于數(shù)據(jù)量不大的加密,比如加密對(duì)稱(chēng)加密的密鑰。

RSA實(shí)現(xiàn)C# 加密的過(guò)程實(shí)例:

RSACryptoServiceProvider 的名稱(chēng)空間是:

  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. //顯示加密后的,為了顯示不可見(jiàn)字符,使用的是 Base64 編碼。  

使用 RSACryptoServiceProvider() 創(chuàng)建 RSACryptoServiceProvider 實(shí)例時(shí),自動(dòng)產(chǎn)生密鑰。

RSA 實(shí)際應(yīng)用中是:接收方產(chǎn)生公鑰和私鑰,發(fā)送方用其公鑰加密,再把加密后的內(nèi)容發(fā)送給接收方。

CspParameters 的名稱(chēng)空間是:

  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. //發(fā)送方使用接收方給它的公鑰進(jìn)行加密  
  15.  
  16. string plaintext =   
  17. "前幾天我碰到一個(gè)朋友,約我跟馬賊打架,  
  18. 我立馬答應(yīng)了他,因?yàn)槲矣X(jué)得這件事好無(wú)聊。";  
  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.  //顯示發(fā)送方公鑰  
  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//密鑰要保存起來(lái)  
  44. //rsaSend.Clear();  
  45. rsaReceive.PersistKeyInCsp = true;  
  46. //rsaReceive.Clear();  

在上面的代碼中,我們使用 CspParameters 將密鑰保存起來(lái),ToXmlString 和 FromXmlString 將接收方的公鑰告訴給發(fā)送方。

RSA實(shí)現(xiàn)C# 加密的實(shí)際操作就向你介紹到這里,希望對(duì)你了解和學(xué)習(xí)C# 加密以及RSA的應(yīng)用有所幫助。

【編輯推薦】

  1. 淺析XML序列化的優(yōu)缺點(diǎn)
  2. 淺析C# XML編程實(shí)現(xiàn)添加X(jué)ML文件內(nèi)容
  3. C# XML編程刪除XML文件內(nèi)容操作詳解
  4. 淺談C# 加密中MD5和SHA1加密實(shí)現(xiàn)
  5. 簡(jiǎn)析散列算法在C# 加密中的應(yīng)用
責(zé)任編輯:仲衡 來(lái)源: cftea.com
相關(guān)推薦

2009-09-09 18:57:26

C# 加密TripleDES

2009-08-13 18:12:11

C#數(shù)據(jù)加密

2009-08-25 18:04:30

C#實(shí)現(xiàn)Singlet

2009-08-31 16:23:13

C#接口

2009-08-25 10:44:50

C#實(shí)現(xiàn)多語(yǔ)言

2009-08-25 17:43:17

C#串口監(jiān)聽(tīng)

2009-08-21 10:13:02

C#異步初步

2009-08-26 09:22:44

C#實(shí)現(xiàn)打印功能

2009-08-26 11:07:36

C#打印窗體

2009-08-26 12:59:08

C#打印設(shè)置

2009-08-26 11:32:37

C#打印文檔

2009-09-03 14:55:56

C#實(shí)現(xiàn)DataGri

2009-09-09 12:55:59

C# TextBox事

2009-08-20 16:33:44

Socket異步通訊

2009-09-07 03:44:50

C#窗體間傳值

2009-09-10 16:30:11

C#排序函數(shù)

2024-04-15 10:32:14

2024-10-31 11:03:06

C#橢圓運(yùn)動(dòng)緩沖

2012-10-31 17:37:48

2009-09-01 16:07:04

C#命名規(guī)約
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)