C# AES对称加密算法

AES算法的keysize有一定限制。具体来说,AES算法支持的keysize为 128 bits、192 bits 和 256 bits,而且只能以16 bits(即2个字节)为步长递增。也就是说,支持的有效的 keysize 可以是:128、160、192、224 或 256。需要注意的是,AES算法的 keysize 越大,加密强度越高,但同时也会增加加密运算所需的时间和计算资源。因此,在实际应用中,需要根据实际需求和环境对 keysize 进行合理的选择。

代码

using System;
using System.Security.Cryptography;
using System.Text;

//AES对称加密算法(ECB模式,无需初始化向量)
internal class AESHelper
{
    /// <summary>
    /// AES算法的keysize有一定限制。
    /// 具体来说,AES算法支持的keysize为 128 bits、192 bits 和 256 bits,而且只能以16 bits(即2个字节)为步长递增。
    /// 也就是说,支持的有效的 keysize 可以是:128、160、192、224 或 256。
    /// 需要注意的是,AES算法的 keysize 越大,加密强度越高,但同时也会增加加密运算所需的时间和计算资源。
    /// 因此,在实际应用中,需要根据实际需求和环境对 keysize 进行合理的选择。
    /// </summary>
    private static readonly int KeySize = 256;

    /// <summary>
    /// 生成秘钥
    /// </summary>
    /// <returns></returns>
    public static string GenerateKey()
    {
        using (var aes = Aes.Create())
        {
            aes.KeySize = KeySize;
            aes.Mode = CipherMode.ECB; // ECB 模式无需 IV 向量
            aes.Padding = PaddingMode.PKCS7;

            aes.GenerateKey();
            return Convert.ToBase64String(aes.Key);
        }
    }

    /// <summary>
    /// 加密
    /// </summary>
    /// <param name="plainText">加密的内容</param>
    /// <param name="key">密匙</param>
    /// <returns>加密结果</returns>
    public static string Encrypt(string plainText, string key)
    {
        using (var aes = Aes.Create())
        {
            aes.KeySize = KeySize;
            aes.Mode = CipherMode.ECB; // ECB 模式无需 IV 向量
            aes.Padding = PaddingMode.PKCS7;
            aes.Key = Convert.FromBase64String(key);

            ICryptoTransform encryptor = aes.CreateEncryptor();

            byte[] plainBytes = Encoding.UTF8.GetBytes(plainText);
            byte[] cipherBytes = encryptor.TransformFinalBlock(plainBytes, 0, plainBytes.Length);

            return Convert.ToBase64String(cipherBytes);
        }
    }

    /// <summary>
    /// 解密
    /// </summary>
    /// <param name="cipherText">解密的内容</param>
    /// <param name="key">密匙</param>
    /// <returns>解密结果</returns>
    public static string Decrypt(string cipherText, string key)
    {
        using (var aes = Aes.Create())
        {
            aes.KeySize = KeySize;
            aes.Mode = CipherMode.ECB; // ECB 模式无需 IV 向量
            aes.Padding = PaddingMode.PKCS7;
            aes.Key = Convert.FromBase64String(key);

            ICryptoTransform decryptor = aes.CreateDecryptor();

            byte[] cipherBytes = Convert.FromBase64String(cipherText);
            byte[] plainBytes = decryptor.TransformFinalBlock(cipherBytes, 0, cipherBytes.Length);

            return Encoding.UTF8.GetString(plainBytes);
        }
    }
}

end

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值