C#實現AES-CBC加密工具類(含完整源碼及使用教程)

一、AES-CBC加密應用場景

AES(Advanced Encryption Standard)作為全球公認的安全加密標準,廣泛使用在以下場景:

  1. API通信加密:保護HTTP接口傳輸的敏感數據(如身份令牌、支付信息)
  2. 文件安全存儲:加密本地配置文件、數據庫連接字符串等
  3. 用戶隱私保護:加密存儲密碼、身份證號等PII(個人身份信息)
  4. 跨平臺數據交換:與Java/Python等其他語言實現的加密系統互通
  5. 物聯網設備通信:保障設備與控制端的數據傳輸安全

其中CBC模式(密碼塊鏈模式)通過引入初始化向量(IV),能有效防止相同明文生成相同密文的問題,安全性優于ECB模式。


二、工具類完整實現代碼

using System;
using System.IO;
using System.Text;
using System.Security.Cryptography;/// <summary>
/// AES-CBC加密工具類(128/192/256位密鑰)
/// </summary>
public static class AesCbcHelper
{/// <summary>/// AES加密(輸出Base64字符串)/// </summary>/// <param name="plainText">明文</param>/// <param name="key">密鑰(16/24/32字節)</param>/// <param name="iv">初始化向量(16字節)</param>public static string Encrypt(string plainText, byte[] key, byte[] iv){// 參數校驗ValidateKeyAndIV(key, iv);using (Aes aesAlg = Aes.Create()){// 配置加密參數aesAlg.Key = key;aesAlg.IV = iv;aesAlg.Mode = CipherMode.CBC;     // 設置為CBC模式[4,9](@ref)aesAlg.Padding = PaddingMode.PKCS7; // 使用PKCS#7填充[3,6](@ref)// 創建加密器ICryptoTransform encryptor = aesAlg.CreateEncryptor();// 執行加密using (MemoryStream msEncrypt = new MemoryStream()){using (CryptoStream csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write)){using (StreamWriter swEncrypt = new StreamWriter(csEncrypt)){swEncrypt.Write(plainText);}return Convert.ToBase64String(msEncrypt.ToArray());}}}}/// <summary>/// AES解密(輸入Base64字符串)/// </summary>public static string Decrypt(string cipherText, byte[] key, byte[] iv){ValidateKeyAndIV(key, iv);using (Aes aesAlg = Aes.Create()){aesAlg.Key = key;aesAlg.IV = iv;aesAlg.Mode = CipherMode.CBC;aesAlg.Padding = PaddingMode.PKCS7;ICryptoTransform decryptor = aesAlg.CreateDecryptor();using (MemoryStream msDecrypt = new MemoryStream(Convert.FromBase64String(cipherText))){using (CryptoStream csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Read)){using (StreamReader srDecrypt = new StreamReader(csDecrypt)){return srDecrypt.ReadToEnd();}}}}}/// <summary>/// 密鑰與IV校驗/// </summary>private static void ValidateKeyAndIV(byte[] key, byte[] iv){if (!IsValidKeySize(key.Length))throw new ArgumentException("密鑰長度應為16/24/32字節");if (iv.Length != 16)throw new ArgumentException("IV長度必須為16字節");}/// <summary>/// 驗證密鑰長度/// </summary>private static bool IsValidKeySize(int keySize){return keySize == 16 || keySize == 24 || keySize == 32; // 支持128/192/256位[9](@ref)}
}

三、使用教程(控制臺示例)

class Program
{static void Main(){try{// 原始數據string original = "CSDN開發者社區2023";// 生成密鑰和IV(生產環境應從安全存儲獲取)byte[] key = Encoding.UTF8.GetBytes("ThisIsASecretKey16"); // 16字節密鑰byte[] iv = Encoding.UTF8.GetBytes("16ByteInitVector");     // 16字節IV// 加密string encrypted = AesCbcHelper.Encrypt(original, key, iv);Console.WriteLine($"加密結果:{encrypted}");// 解密string decrypted = AesCbcHelper.Decrypt(encrypted, key, iv);Console.WriteLine($"解密結果:{decrypted}");}catch (CryptographicException ex){Console.WriteLine($"加解密失敗:{ex.Message}");}}
}

四、關鍵功能說明

1. 參數驗證機制

? 密鑰長度強制校驗(16/24/32字節)

? IV長度必須為16字節

? 自動處理Base64編解碼

2. 安全增強特性

? 使用CBC模式防止模式攻擊

? 采用PKCS#7填充標準

? 通過using語句確保資源釋放

3. 異常處理建議

? 捕獲CryptographicException處理加解密失敗

? 使用ArgumentException提示參數錯誤

? 建議在生產環境中記錄操作日志


五、注意事項

  1. 密鑰管理:切勿硬編碼密鑰,應使用密鑰管理系統(如Azure Key Vault)
  2. IV生成規則:每次加密應生成隨機IV(示例為演示固定值)
  3. 性能優化:對大數據流建議采用分塊加密
  4. 跨平臺互通:與其他語言對接需統一字符編碼(推薦UTF-8)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/72160.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/72160.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/72160.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

docker-compose部署MongoDB分片集群

前言 MongoDB 使用 keyFile 進行 節點間身份驗證,我們需要先創建一個 keyFile 并確保所有副本集的節點使用相同的 keyFile。 openssl rand -base64 756 > mongo-keyfile chmod 400 mongo-keyfiledocker-compose部署分片集群 無密碼方式 # docker-compose-mongodb.yml s…

3-003:在 MySQL 中建索引時需要注意哪些事項?

在 MySQL 中創建索引時&#xff0c;需要注意以下事項&#xff0c;以確保索引高效且合理&#xff1a; 1. 選擇合適的索引類型 主鍵索引&#xff08;PRIMARY KEY&#xff09;&#xff1a;每個表只能有一個&#xff0c;默認是聚簇索引。唯一索引&#xff08;UNIQUE&#xff09;&…

在 Linux 系統中,區分**磁盤(物理/虛擬存儲設備)和分區(磁盤的邏輯劃分)

在 Linux 系統中&#xff0c;區分**磁盤&#xff08;物理/虛擬存儲設備&#xff09;和分區&#xff08;磁盤的邏輯劃分&#xff09;**是管理存儲的基礎。以下是詳細的區分方法和操作示例&#xff1a; 一、通過設備命名規則區分 Linux 中磁盤和分區的命名遵循特定規則&#xff…

MongoDB中的游標(Cursor)

游標&#xff08;Cursor&#xff09;在MongoDB中是一個重要的概念&#xff0c;它用于逐條遍歷查詢結果集&#xff0c;特別適用于處理大量數據時。 一、游標的定義與作用 定義&#xff1a; 游標是一種能從數據記錄的結果集中每次提取一條記錄的機制。在MongoDB中&#xff0c;游…

【從零開始學習計算機科學】編譯原理(七)運行時刻環境

【從零開始學習計算機科學】編譯原理(七)運行時刻環境 運行時刻環境存儲組織空間的棧式分配活動樹活動記錄和控制棧簡單棧式存貯分配C語言的過程調用和過程返回時的存貯管理堆式存儲分配堆式存儲分配的功能垃圾回收基于跟蹤的垃圾回收短停頓垃圾回收運行時刻環境 存儲組織 …

2025-03-08 學習記錄--C/C++-PTA 習題10-1 判斷滿足條件的三位數

合抱之木&#xff0c;生于毫末&#xff1b;九層之臺&#xff0c;起于累土&#xff1b;千里之行&#xff0c;始于足下。&#x1f4aa;&#x1f3fb; 一、題目描述 ?? 裁判測試程序樣例&#xff1a; #include <stdio.h> #include <math.h>int search( int n );int…

【ArcGIS】地理坐標系

文章目錄 一、坐標系理論體系深度解析1.1 地球形態的數學表達演進史1.1.1 地球曲率的認知變化1.1.2 參考橢球體參數對比表 1.2 地理坐標系的三維密碼1.2.1 經緯度的本質1.2.2 大地基準面&#xff08;Datum&#xff09;的奧秘 1.3 投影坐標系&#xff1a;平面世界的誕生1.3.1 投…

DeepSeek刷力扣輔助題單 存留記錄

最近感覺被什么東西阻擋了腳步,經大佬建議,做算法題提升一下思維 首先,我不認為算法題要死磕,因為我沒有那個天賦,但是我還是要嘴硬一下 其次,我沒有計算機基礎的學習背景,因為我是修飛機專升本來的自動化專業,24年七月幾乎零基礎學習Unity 和 C#,努力學習到現在感覺已經盡力了…

化工廠防爆氣象站:為石油化工、天然氣等領域提供安全保障

【TH-FB02】在石油化工、天然氣等高危行業中&#xff0c;安全生產是至關重要的。這些行業常常面臨著易燃易爆、有毒有害等潛在風險&#xff0c;因此&#xff0c;對氣象條件的監測和預警顯得尤為重要。化工廠防爆氣象站作為一種專門設計用于這些特殊環境的氣象監測設備&#xff…

《MySQL數據庫從零搭建到高效管理|庫的基本操作》

目錄 一、數據庫的操作 1.1 展示數據庫 1.2 創建數據庫 1.3 使用數據庫 1.4 查看當前數據庫 1.5 刪除數據庫 1.6 小結 二、常用數據類型 2.1 數值類型 2.2 字符串類型 2.3 日期類型 一、數據庫的操作 打開MySQL命令行客戶端&#xff0c;安裝完MySQL后會有兩個客戶端…

計算機考研C語言

C語言程序設計從入門到精通【2025完整版】考研復試 嵌入式 計算機二級 軟考 專升本也適用_嗶哩嗶哩_bilibili 1、第一個C程序 helloC #include <stdio.h>int main(){printf("hehe");return 0;}每個C語言程序不管有多少行代碼&#xff0c;都是從main函數開始執…

力扣hot100二刷——鏈表

第二次刷題不在idea寫代碼&#xff0c;而是直接在leetcode網站上寫&#xff0c;“逼”自己掌握常用的函數。 標志掌握程度解釋辦法?Fully 完全掌握看到題目就有思路&#xff0c;編程也很流利??Basically 基本掌握需要稍作思考&#xff0c;或者看到提示方法后能解答???Sl…

Word 小黑第2套

對應大貓42 Word1 從文件中導入新樣式 樣式組 -管理樣式 -導入導出 -關閉Normal文件 -打開文件 -修改文件 -選中所需 -復制 調整字符寬度 調整字符間距 -字體組 加寬 適當修改磅值 文字效果通過文字組修改 另起一頁&#xff0c;分隔符&#xff08;布局 -分隔符 -分節符 -下一…

iTextSharp-PDF批量導出

HTML轉PDF批量導出速度太慢且使用Spire.pdf.dll限制頁簽10后需要開通會員才能使用-做出優化 環境&#xff1a;U9 - UI插件 需求&#xff1a;選擇需要導出的客戶查詢對應對賬數據批量導出PDF并彈出下載框保存到默認位置 using System; using System.Collections.Generic; us…

【RabbitMQ】Spring Boot 結合 RabbitMQ 完成應用間的通信

&#x1f525;個人主頁&#xff1a; 中草藥 &#x1f525;專欄&#xff1a;【中間件】企業級中間件剖析 Spring 框架與 RabbitMQ 的整合主要通過 Spring AMQP&#xff08;Advanced Message Queuing Protocol&#xff09;模塊實現&#xff0c;提供了便捷的消息隊列開發能力。 引…

CDefView::_GetPIDL函數分析之ListView_GetItem函數的參數item的item.mask 為LVIF_PARAM

CDefView::_GetPIDL函數分析之ListView_GetItem函數的參數item的item.mask 為LVIF_PARAM 第一部分&#xff1a; 1: kd> t SHELL32!CDefView::_GetPIDL: 001b:77308013 55 push ebp 1: kd> dv this 0x00000015 i 0n21 …

MongoDB分頁實現方式對比:PageRequest vs Skip/Limit

MongoDB分頁實現方式對比&#xff1a;PageRequest vs Skip/Limit 一、基本概念1.1 PageRequest分頁1.2 Skip/Limit分頁 二、主要區別2.1 使用方式2.2 參數計算2.3 適用場景PageRequest適用場景&#xff1a;Skip/Limit適用場景&#xff1a; 三、性能考慮3.1 PageRequest的性能特…

Manus(一種AI代理或自動化工具)與DeepSeek(一種強大的語言模型或AI能力)結合使用任務自動化和智能決策

一、Manus與DeepSeek差異 十分好奇DeepSeek和Manus究竟誰更厲害些&#xff0c;DeepSeek是知識型大腦&#xff0c;Manus則是全能型執行者。即DeepSeek專注于語言處理、知識整合與專業文本生成。其核心優勢在于海量參數支持的深度學習和知識推理能力&#xff0c;例如撰寫論文、潤…

UI自動化:poium測試庫

以下是關于 poium 測試庫 的詳細介紹&#xff0c;涵蓋其核心功能、使用方法及與原生 Selenium 的對比&#xff0c;幫助快速掌握這一工具&#xff1a; 1. poium 簡介 定位&#xff1a;基于 Selenium 的 Page Object 模式增強庫&#xff0c;專注于簡化元素定位和頁面操作。 核心…

C#結構體(Struct)詳解

在 C# 中&#xff0c;?結構體&#xff08;struct&#xff09;? 是一種值類型數據類型&#xff0c;適用于封裝小型數據組。與類&#xff08;class&#xff09;不同&#xff0c;結構體在棧&#xff08;Stack&#xff09;上分配內存&#xff0c;且賦值時會發生值復制。以下是結構…