C#对称加密(AES)的简单代码

一、名词解释

AES:AES(Advanced Encryption Standard)是一种对称加密算法,采用分块加密机制处理128位数据块,支持128/192/256位密钥长度。

Key:密钥,是加密算法的核心参数,用于对数据进行加密或解密。长度通常为128位(16字节)、192位(24字节)或256位(32字节),具体长度根据算法模式选择确定。 ‌

IV:初始化向量,是一个固定长度的随机数,长度为128位(16字节),用于增强加密安全性。其核心作用是确保使用同一密钥加密相同明文时生成不同密文,避免安全漏洞。

二、代码示例

cs 复制代码
using System.Security.Cryptography;

/// <summary>加密字符串</summary>
/// <param name="plainText">需要加密的明文</param>
/// <param name="key">加密密钥</param>
/// <param name="iv">初始化向量</param>
/// <returns>返回Base64编码的字符串</returns>
public string Encrypt(string plainText,string key,string iv) {
    string cipherText;
    using (Aes aes = Aes.Create()) {
        aes.Key=Encoding.UTF8.GetBytes(key);
        aes.IV=Encoding.UTF8.GetBytes(iv);
        ICryptoTransform encryptor = aes.CreateEncryptor();
        byte[] plainTextBytes = Encoding.UTF8.GetBytes(plainText);
        byte[] encryptedData = encryptor.TransformFinalBlock(plainTextBytes, 0, plainTextBytes.Length);
        cipherText = Convert.ToBase64String(encryptedData);
    }
    return cipherText;
}

/// <summary>解密字符串</summary>
/// <param name="cipherText">通过Encrypt加密得到的Base64编码的字符串</param>
/// <param name="key">解密密钥,要与加密密钥相同</param>
/// <param name="iv">初始化向量,要与加密的初始化向量相同</param>
/// <returns>返回解密后的字符串</returns>
public string Decrypt(string cipherText,string key,string iv) {
    string plainText;
    using (Aes aes = Aes.Create()) {
        aes.Key= Encoding.UTF8.GetBytes(key);
        aes.IV = Encoding.UTF8.GetBytes(iv);
        ICryptoTransform decryptor = aes.CreateDecryptor();
        byte[] plainTextBytes=Convert.FromBase64String(cipherText);
        byte[] decryptedData=decryptor.TransformFinalBlock(plainTextBytes,0,plainTextBytes.Length);
        plainText=Encoding.UTF8.GetString(decryptedData);
    }
    return plainText;
}
相关推荐
熊文豪2 小时前
KingbaseES数据库SSL安全传输与数据完整性保护技术详解
数据库·安全·ssl·kingbasees·金仓数据库·电科金仓
ajassi20002 小时前
开源 C# 快速开发(一)基础知识
开源·c#
携欢2 小时前
PortSwigger靶场之Exploiting server-side parameter pollution in a query string通关秘籍
数据库·安全
伊织code12 小时前
WebGoat - 刻意设计的不安全Web应用程序
前端·安全·webgoat
虚行12 小时前
C#上位机 通过ProfitNet连接西门子PLC教程--系统模拟环境搭建
学习·c#·plc
竹等寒12 小时前
Powershell 进阶语(三)
windows·安全
jun~13 小时前
SQLMap数据库枚举靶机(打靶记录)
linux·数据库·笔记·学习·安全·web安全
雪域迷影13 小时前
C++/C#游戏开发引擎和2D/3D图形库
c++·3d·c#
wanhengidc14 小时前
本机网速会影响到云手机的运行吗
运维·服务器·安全·游戏·智能手机