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
  • 最近做項目過程中,使用到了海康相機,官方只提供了C/C++的SDK,沒有搜尋到一個合適的封裝了的C#庫,故自己動手,簡單的封裝了一下,方便大家也方便自己使用和二次開發 ...
  • 前言 MediatR 是 .NET 下的一個實現消息傳遞的庫,輕量級、簡潔高效,用於實現進程內的消息傳遞機制。它基於中介者設計模式,支持請求/響應、命令、查詢、通知和事件等多種消息傳遞模式。通過泛型支持,MediatR 可以智能地調度不同類型的消息,非常適合用於領域事件處理。 在本文中,將通過一個簡 ...
  • 前言 今天給大家推薦一個超實用的開源項目《.NET 7 + Vue 許可權管理系統 小白快速上手》,DncZeus的願景就是做一個.NET 領域小白也能上手的簡易、通用的後臺許可權管理模板系統基礎框架。 不管你是技術小白還是技術大佬或者是不懂前端Vue 的新手,這個項目可以快速上手讓我們從0到1,搭建自 ...
  • 第1章:WPF概述 本章目標 瞭解Windows圖形演化 瞭解WPF高級API 瞭解解析度無關性概念 瞭解WPF體繫結構 瞭解WPF 4.5 WPF概述 ​ 歡迎使用 Windows Presentation Foundation (WPF) 桌面指南,這是一個與解析度無關的 UI 框架,使用基於矢 ...
  • 在日常開發中,並不是所有的功能都是用戶可見的,還在一些背後默默支持的程式,這些程式通常以服務的形式出現,統稱為輔助角色服務。今天以一個簡單的小例子,簡述基於.NET開發輔助角色服務的相關內容,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 第3章:佈局 本章目標 理解佈局的原則 理解佈局的過程 理解佈局的容器 掌握各類佈局容器的運用 理解 WPF 中的佈局 WPF 佈局原則 ​ WPF 視窗只能包含單個元素。為在WPF 視窗中放置多個元素並創建更貼近實用的用戶男面,需要在視窗上放置一個容器,然後在這個容器中添加其他元素。造成這一限制的 ...
  • 前言 在平時項目開發中,定時任務調度是一項重要的功能,廣泛應用於後臺作業、計劃任務和自動化腳本等模塊。 FreeScheduler 是一款輕量級且功能強大的定時任務調度庫,它支持臨時的延時任務和重覆迴圈任務(可持久化),能夠按秒、每天/每周/每月固定時間或自定義間隔執行(CRON 表達式)。 此外 ...
  • 目錄Blazor 組件基礎路由導航參數組件參數路由參數生命周期事件狀態更改組件事件 Blazor 組件 基礎 新建一個項目命名為 MyComponents ,項目模板的交互類型選 Auto ,其它保持預設選項: 客戶端組件 (Auto/WebAssembly): 最終解決方案裡面會有兩個項目:伺服器 ...
  • 先看一下效果吧: isChecked = false 的時候的效果 isChecked = true 的時候的效果 然後我們來實現一下這個效果吧 第一步:創建一個空的wpf項目; 第二步:在項目裡面添加一個checkbox <Grid> <CheckBox HorizontalAlignment=" ...
  • 在編寫上位機軟體時,需要經常處理命令拼接與其他設備進行通信,通常對不同的命令封裝成不同的方法,擴展稍許麻煩。 本次擬以特性方式實現,以兼顧維護性與擴展性。 思想: 一種命令對應一個類,其類中的各個屬性對應各個命令段,通過特性的方式,實現其在這包數據命令中的位置、大端或小端及其轉換為對應的目標類型; ...