.Net 核心相当于 CryptoJS.AES.encrypt

.Net Core Equivalent to CryptoJS.AES.encrypt

我有以下 JavaScript 代码使用 CryptoJS 库中的 CryptoJS.AES.encrypt 函数,我正在寻找等效的 .Net Core 代码,有人可以指导吗?

        var myData = '';
        var key1 = '';
        var key2 = '';

        var encryptedData = CryptoJS.AES.encrypt(CryptoJS.enc.Utf8.parse(myData.substr(0, myData.length - 1)), CryptoJS.enc.Utf8.parse(key1),
            {
                keySize: 128 / 8,
                iv: CryptoJS.enc.Utf8.parse(key2),
                mode: CryptoJS.mode.CBC,
                padding: CryptoJS.pad.Pkcs7
            });

编辑

我找到了以下 .Net Core 代码:

public string EncryptString(string text, string keyString, string ivString)
        {
            var key = Encoding.UTF8.GetBytes(keyString);

            using (var aesAlg = Aes.Create())
            {
                using (var encryptor = aesAlg.CreateEncryptor(key, aesAlg.IV))
                {
                    using (var msEncrypt = new MemoryStream())
                    {
                        using (var csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write))
                        using (var swEncrypt = new StreamWriter(csEncrypt))
                        {
                            swEncrypt.Write(text);
                        }

                        var iv = aesAlg.IV;

                        var decryptedContent = msEncrypt.ToArray();

                        var result = new byte[iv.Length + decryptedContent.Length];

                        Buffer.BlockCopy(iv, 0, result, 0, iv.Length);
                        Buffer.BlockCopy(decryptedContent, 0, result, iv.Length, decryptedContent.Length);

                        return Convert.ToBase64String(result);
                    }
                }
            }
        }

但我不确定如何按照 JavaScript 代码中指定的方式指定这些选项:

 {
                    keySize: 128 / 8,
                    iv: CryptoJS.enc.Utf8.parse(key2),
                    mode: CryptoJS.mode.CBC,
                    padding: CryptoJS.pad.Pkcs7
                }

编辑 2

我根据 Topaco 的建议更新了我的 C# 代码,下面是我的代码。 但是当我测试它时,我的 C# 代码和 JavaScript 代码的输出是不同的,任何人都可以指导缺少什么吗?

public string RequestHash(string text, string keyString, string ivString)
        {
            var key = Encoding.UTF8.GetBytes(keyString);
            var iv = Encoding.UTF8.GetBytes(ivString);

            using (var aesAlg = Aes.Create())
            {
                using (var encryptor = aesAlg.CreateEncryptor(key, iv))
                {
                    using (var msEncrypt = new MemoryStream())
                    {
                        using (var csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write))
                        using (var swEncrypt = new StreamWriter(csEncrypt))
                        {
                            swEncrypt.Write(text);
                        }

                        var decryptedContent = msEncrypt.ToArray();
                        return Convert.ToBase64String(decryptedContent);
                    }
                }
            }
        } 

非常感谢 Topaco 的帮助,非常感谢!

这是我的最终代码:

public string RequestHash(string text, string keyString, string ivString)
{
    var key = Encoding.UTF8.GetBytes(keyString);
    var iv = Encoding.UTF8.GetBytes(ivString);

    using (var aesAlg = Aes.Create())
    {
        using (var encryptor = aesAlg.CreateEncryptor(key, iv))
        {
            using (var msEncrypt = new MemoryStream())
            {
                using (var csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write))
                using (var swEncrypt = new StreamWriter(csEncrypt))
                {
                    swEncrypt.Write(text);
                }

                var decryptedContent = msEncrypt.ToArray();
                return Convert.ToBase64String(decryptedContent);
            }
        }
    }
}