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.mzph.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;且赋值时会发生值复制。以下是结构…