C#不對稱加密

来源:http://www.cnblogs.com/wangjinsns/archive/2016/04/22/5419991.html
-Advertisement-
Play Games

對稱加密的缺點是雙方使用相同的密鑰和IV進行加密、解密。由於接收方必須知道密鑰和IV才能解密數據,因此發送方需要先將密鑰和IV傳遞給接收方。這就 有一個問題,如果攻擊者截獲了密鑰和IV,也就等於知道瞭如何解密數據!如何保證發送方傳遞給接收方的密鑰和IV不被攻擊者截獲並破譯呢? 源碼:http://w ...


  對稱加密的缺點是雙方使用相同的密鑰和IV進行加密、解密。由於接收方必須知道密鑰和IV才能解密數據,因此發送方需要先將密鑰和IV傳遞給接收方。這就 有一個問題,如果攻擊者截獲了密鑰和IV,也就等於知道瞭如何解密數據!如何保證發送方傳遞給接收方的密鑰和IV不被攻擊者截獲並破譯呢?

源碼:http://www.jinhusns.com/Products/Download/?type=xcj

      不對稱加密也叫公鑰加密,這種技術使用不同的加密密鑰與解密密鑰,是一種“由已知加密密鑰推導出解密密鑰在計算上是不可行的”密碼體制。不對稱加密產生的主要原因有兩個,一是對稱加密的密鑰分配問題,另一個是由於對數字簽名的需求。 不對稱加密使用一個需要保密的私鑰和一個可以對任何人公開的公鑰,即使用公鑰/私鑰對來加密和解密數據。公鑰和私鑰都在數學上相關聯,用公鑰加 密的數據只能用私鑰解密,反之,用私鑰加密的數據只能用公鑰解密。兩個密鑰對於通信會話都是惟一的。公鑰加密演算法也稱為不對稱演算法,原因是需要用一個密鑰 加密數據而需要用另一個密鑰來解密數據       私鑰加密演算法使用長度可變的緩衝區,而公鑰加密演算法使用固定大小的緩衝區,無法像私鑰演算法那樣將數據鏈接起來成為流,因此無法使用與對稱操作相同的流模型。這是編寫程式時必須註意的問題。       為什麼不對稱加密更不容易被攻擊呢?關鍵在於對私鑰的管理上。在對稱加密中,發送方必須先將解密密鑰傳遞給接收方,接收方纔能解密。如果避免通過不安全的網路傳遞私鑰,不就解決這個問題了嗎?       不對稱加密的關鍵就在於此。使用不對稱加密演算法加密數據後,私鑰不是發送方傳遞給接收方的,而是接收方先生成一個公鑰/私鑰對,在接收被加密的數據前,先 將該公鑰傳遞給發送方;註意,從公鑰推導出私鑰是不可能的,所以不怕通過網路傳遞時被攻擊者截獲公鑰。發送方得到此公鑰後,使用此公鑰加密數據,再將加密 後的數據通過網路傳遞給接收方;接收方收到加密後的數據後,再用私鑰進行解密。由於沒有傳遞私鑰,從而保證了數據安全性。   .NET Framework提供以下實現不對稱加密演算法的類: •DSACryptoServiceProvider  •RSACryptoServiceProvider 

 RSACryptoServiceProvider類使用加密服務提供程式提供的RSA演算法實現不對稱加密和解密。加密服務提供程式 CSP(Cryptographic Service Provider)是微軟在Windows操作系統中內置的加密處理模塊,RSACryptoServiceProvider類已經對其提供的相關介面和 參數進行了封裝,所以即使我們不知道CSP內部是如何實現的,也一樣可以使用其提供的功能 

RSA不對稱加密例子

        private void buttonOK_Click(object sender, EventArgs e)         {             //使用預設密鑰創建RSACryptoServiceProvider對象             RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();             //顯示包含公鑰/私鑰對的XML表示形式,如果只顯示公鑰,將參數改為false即可             richTextBoxKeys.Text = rsa.ToXmlString(true);//得到公鑰/私鑰對(實際沒什麼意義,一般情況下通過得到公鑰發送給服務端,服務端用FromXmlString接收公鑰,進行加密後傳輸)             //將被加密的字元串轉換為位元組數組             byte[] dataToEncrypt = Encoding.UTF8.GetBytes(textBoxInput.Text);             try             {                 //得到加密後的位元組數組                 byte[] encryptedData = rsa.Encrypt(dataToEncrypt, false);                 textBoxEncrypt.Text = Encoding.UTF8.GetString(encryptedData);                 //得到解密後的位元組數組                 byte[] decryptedData = rsa.Decrypt(encryptedData, false);                 textBoxDecrypt.Text = Encoding.UTF8.GetString(decryptedData);             }             catch (Exception err)             {                 MessageBox.Show(err.Message);             }         }
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、改表法 mysql>use mysql; mysql>update user set host = '%' where user = 'root'; 2、授權法 例如,你想myuser使用mypassword從任何主機連接到mysql伺服器的話。 GRANT ALL PRIVILEGES ON ...
  • 介紹 MySQL5.7出來也有大半年了,業內也一直在宣傳5.7有多麼的N,官網的也是宣傳5.7有好幾倍的速度的提升包括在語法方面更多的支持、JOSN、並行複製等;但是一直期待的線程池還是沒有在5.7中出現有點遺憾。忍不住也下載一個來玩玩,mysql5.7的安裝相對於5.6還是有點區別,本章主要介紹二 ...
  • What/Sphinx是什麼 定義 Sphinx是一個全文檢索引擎。 特性 索引和性能優異 易於集成SQL和XML數據源,並可使用SphinxAPI、SphinxQL或者SphinxSE搜索介面 易於通過分散式搜索進行擴展 高速的索引建立(在當代CPU上,峰值性能可達到10 ~ 15MB/秒) 高性 ...
  • 培訓大數據架構開發、挖掘分析! 從零基礎到高級,一對一培訓![技術QQ:2937765541] 課程體系: 獲取視頻資料和培訓解答技術支持地址 課程展示(大數據技術很廣,一直線上為你培訓解答!): 獲取視頻資料和培訓解答技術支持地址 ...
  • //獲取完整url (協議名+功能變數名稱+站點名+文件名+參數) string fullUrl = Request.Url.ToString(); //獲取客戶端請求的URL信息(不包括主機和埠) string rawUrl = Request.RawUrl; //獲取站點名+頁面名 string ab ...
  • 要矩形裁切影像圖,首先得繪製一個裁切矩形,用這個矩形作為一個geometry來裁切 裁切界面如圖所示: 代碼如下: ...
  • 使用上兩者的介面都類似字典,並且SortedList的比如Find,FindIndex,RemoveAll常用方法都沒提供。 數據結構上二者差異比較大,SortedList查找數據極快,但添加新元素,刪除元素較慢,SortedDictionary查找,添加,刪除速度都比較平均。 博友的測試結果: 直 ...
  • Javascript在瀏覽器中的性能,可以說是前端開發者所要面對的最重要的可用性問題。 源碼:http://www.jinhusns.com/Products/Download/?type=xcj 在Yahoo的Yslow23條規則當中,其中一條是將JS放在底部 。原因是,事實上,大多數瀏覽器使用單 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...