这个问题可能是由于.Net 6中Aes算法默认使用了更高级的加密模式(CBC)导致的。如果你在.Net 6中使用Aes,你应该显式指定加密模式。
以下是一个示例,使用CBC模式加密和解密:
// 加密
using Aes aes = Aes.Create();
aes.Key = key;
aes.IV = iv;
aes.Mode = CipherMode.CBC;
byte[] encrypted;
using MemoryStream encryptStream = new MemoryStream();
using CryptoStream cryptoStream = new CryptoStream(encryptStream, aes.CreateEncryptor(), CryptoStreamMode.Write);
cryptoStream.Write(data, 0, data.Length);
cryptoStream.FlushFinalBlock();
encrypted = encryptStream.ToArray();
// 解密
using MemoryStream decryptStream = new MemoryStream(encrypted);
using CryptoStream decryptorStream = new CryptoStream(decryptStream, aes.CreateDecryptor(), CryptoStreamMode.Read);
using StreamReader streamReader = new StreamReader(decryptorStream);
string decryptedData = streamReader.ReadToEnd();
注意:将加密模式指定为CBC可能会导致将来出现漏洞。因此,如果可能的话,应该使用更安全的加密模式(如GCM)来保护你的数据。
上一篇:AES加密和解密功能无法正常工作