AES加密解密(根據指定秘鑰)

来源:https://www.cnblogs.com/ysaw/archive/2020/07/22/13361079.html
-Advertisement-
Play Games

最近在做調用第三方介面,要求入參AES加密,並且秘鑰為16位的長度,在此記錄一下。 首先引用命名空間: using System.IO; using System.Text; using System.Security.Cryptography; 1 /// <summary> 2 /// AES加 ...


最近在做調用第三方介面,要求入參AES加密,並且秘鑰為16位的長度,在此記錄一下。

首先引用命名空間:

using System.IO;

using System.Text;

using System.Security.Cryptography;

 1  /// <summary>
 2         /// AES加密(無向量)
 3         /// </summary>
 4         /// <param name="plainBytes">被加密的明文</param>
 5         /// <param name="key">密鑰</param>
 6         /// <returns>密文</returns>
 7         public  string AESEncrypt(string Data, string Key)
 8         {
 9             MemoryStream mStream = new MemoryStream();
10             RijndaelManaged aes = new RijndaelManaged();
11 
12             byte[] plainBytes = Encoding.UTF8.GetBytes(Data);
13             Byte[] bKey = new Byte[16];
14             Array.Copy(Encoding.UTF8.GetBytes(Key.PadRight(bKey.Length)), bKey, bKey.Length);
15 
16             aes.Mode = CipherMode.ECB;
17             aes.Padding = PaddingMode.PKCS7;
18             aes.KeySize = 128;
19             //aes.Key = _key;
20             aes.Key = bKey;
21             //aes.IV = _iV;
22             CryptoStream cryptoStream = new CryptoStream(mStream, aes.CreateEncryptor(), CryptoStreamMode.Write);
23             try
24             {
25                 cryptoStream.Write(plainBytes, 0, plainBytes.Length);
26                 cryptoStream.FlushFinalBlock();
27                 return Convert.ToBase64String(mStream.ToArray());
28             }
29             finally
30             {
31                 cryptoStream.Close();
32                 mStream.Close();
33                 aes.Clear();
34             }
35         }

 1  #region 解密
 2         /// <summary>
 3         /// AES解密(無向量)
 4         /// </summary>
 5         /// <param name="encryptedBytes">被加密的明文</param>
 6         /// <param name="key">密鑰</param>
 7         /// <returns>明文</returns>
 8         public  string AESDecrypt(String Data, String Key)
 9         {
10             Byte[] encryptedBytes = Convert.FromBase64String(Data);
11             Byte[] bKey = new Byte[16];
12             Array.Copy(Encoding.UTF8.GetBytes(Key.PadRight(bKey.Length)), bKey, bKey.Length);
13 
14             MemoryStream mStream = new MemoryStream(encryptedBytes);
15             //mStream.Write( encryptedBytes, 0, encryptedBytes.Length );
16             //mStream.Seek( 0, SeekOrigin.Begin );
17             RijndaelManaged aes = new RijndaelManaged();
18             aes.Mode = CipherMode.ECB;
19             aes.Padding = PaddingMode.PKCS7;
20             aes.KeySize = 128;
21             aes.Key = bKey;
22             //aes.IV = _iV;
23             CryptoStream cryptoStream = new CryptoStream(mStream, aes.CreateDecryptor(), CryptoStreamMode.Read);
24             try
25             {
26                 byte[] tmp = new byte[encryptedBytes.Length + 32];
27                 int len = cryptoStream.Read(tmp, 0, encryptedBytes.Length + 32);
28                 byte[] ret = new byte[len];
29                 Array.Copy(tmp, 0, ret, 0, len);
30                 return Encoding.UTF8.GetString(ret);
31             }
32             finally
33             {
34                 cryptoStream.Close();
35                 mStream.Close();
36                 aes.Clear();
37             }
38         }
39         #endregion

調用時:string sendData = publicSH.AESDecrypt(sendData, "HYYSIENDEUFHVKDA");//返回信息解密 sendData 為要加密或者解密的信息 ,第二個參數是16位的秘鑰




 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、迭代器 1、迭代器 what 器=》工具 迭代:是一個重覆的過程,但每次重覆都是基於上一次的結果而來的 迭代器:就是一種不依賴於索引的取值工具 ps:迭代器可以裝下無窮個值,也可以產生無窮個值 names=["egon",'lqz','yj'] count = 1 while count < l ...
  • 從沒有被釋放的記憶體塊,可以獲得文件名、行號,泄漏多少位元組,會列印顯示出來。 ...
  • 服裝價格變動,觸發淘寶發佈活動和消費者購買衣服事件流 1 public class EventStandard 2 { 3 public class Clothes { 4 5 /// <summary> 6 /// 服裝編碼 7 /// </summary> 8 public string Id ...
  • 源碼還需優化,不喜勿噴。 微信官方文檔 : https://developers.weixin.qq.com/doc/oplatform/Website_App/WeChat_Login/Wechat_Login.html 前期準備: 1.微信開放平臺開發者資質認證 https://open.wei ...
  • 今天總結一下,調用第三方介面地址,以POST方式進行HTTP請求,並且入參為JSON格式方法: 引用:using System.Text;using System.Net;using System.IO; string url="http://";//第三方介面地址 paramStr //json字 ...
  • 1.首先使用VS創建WebAPI項目 (這裡有個幫助類,將此幫助類複製到項目里,有興趣可以學著寫) //文件上傳下載,導入導出輔助類 public class APIFileHelp { //此為限制文件格式 public string[] ExtentsfileName = new string[ ...
  • 今天總結一下 關於XML字元串轉DataTable 方法: 引用:using System.Xml; using Newtonsoft.Json;using System.Data; using System.Collections; 首先,定義一個xml字元串來接收傳過來的數據, string x ...
  • 今天總結一下關於DataTable,XML轉JSON的方法: 首先需要引入命名空間: using Newtonsoft.Json 1 public string DataTableToJsonWithStringBuilder(DataTable table) 2 { 3 var jsonStrin ...
一周排行
    -Advertisement-
    Play Games
  • 隨著Aspire發佈preview5的發佈,Microsoft.Extensions.ServiceDiscovery隨之更新, 服務註冊發現這個屬於老掉牙的話題解決什麼問題就不贅述了,這裡主要講講Microsoft.Extensions.ServiceDiscovery(preview5)以及如何 ...
  • 概述:通過使用`SemaphoreSlim`,可以簡單而有效地限制非同步HTTP請求的併發量,確保在任何給定時間內不超過20個網頁同時下載。`ParallelOptions`不適用於非同步操作,但可考慮使用`Parallel.ForEach`,儘管在非同步場景中謹慎使用。 對於併發非同步 I/O 操作的數量 ...
  • 1.Linux上安裝Docken 伺服器系統版本以及內核版本:cat /etc/redhat-release 查看伺服器內核版本:uname -r 安裝依賴包:yum install -y yum-utils device-mapper-persistent-data lvm2 設置阿裡雲鏡像源:y ...
  • 概述:WPF界面綁定和渲染大量數據可能導致性能問題。通過啟用UI虛擬化、非同步載入和數據分頁,可以有效提高界面響應性能。以下是簡單示例演示這些優化方法。 在WPF中,當你嘗試綁定和渲染大量的數據項時,性能問題可能出現。以下是一些可能導致性能慢的原因以及優化方法: UI 虛擬化: WPF提供了虛擬化技術 ...
  • 引言 上一章節介紹了 TDD 的三大法則,今天我們講一下在單元測試中模擬對象的使用。 Fake Fake - Fake 是一個通用術語,可用於描述 stub或 mock 對象。 它是 stub 還是 mock 取決於使用它的上下文。 也就是說,Fake 可以是 stub 或 mock Mock - ...
  • 為.net6在CentOS7上面做準備,先在vmware虛擬機安裝CentOS 7.9 新建CentOS764位的系統 因為CentOS8不更新了,所以安裝7;簡單就一筆帶過了 選擇下載好的操作系統的iso文件,下載地址https://mirrors.aliyun.com/centos/7.9.20 ...
  • 經過前面幾篇的學習,我們瞭解到指令的大概分類,如:參數載入指令,該載入指令以 Ld 開頭,將參數載入到棧中,以便於後續執行操作命令。參數存儲指令,其指令以 St 開頭,將棧中的數據,存儲到指定的變數中,以方便後續使用。創建實例指令,其指令以 New 開頭,用於在運行時動態生成並初始化對象。方法調用指... ...
  • LiteDB 是一個輕量級的嵌入式 NoSQL 資料庫,其設計理念與 MongoDB 類似,但它是完全使用 C# 開發的,因此與 C# 應用程式的集成非常順暢。與 SQLite 相比,LiteDB 提供了 NoSQL(即鍵值對)的數據存儲方式,並且是一個開源且免費的項目。它適用於桌面、移動以及 We ...
  • 1 開源解析和拆分文檔 第三方的工具去對文件解析拆分,去將我們的文件內容給提取出來,並將我們的文檔內容去拆分成一個小的chunk。常見的PDF word mark down, JSON、HTML。都可以有很好的一些模塊去把這些文件去進行一個東西去提取。 優勢 支持豐富的文檔類型 每種文檔多樣化選擇 ...
  • OOM是什麼?英文全稱為 OutOfMemoryError(記憶體溢出錯誤)。當程式發生OOM時,如何去定位導致異常的代碼還是挺麻煩的。 要檢查OOM發生的原因,首先需要瞭解各種OOM情況下會報的異常信息。這樣能縮小排查範圍,再結合異常堆棧、heapDump文件、JVM分析工具和業務代碼來判斷具體是哪 ...