2

我正在尝试在动作脚本和 C# 之间共享加密

我的任务是在 C# 中解密以下消息

f1ca22a365ba54c005c3eb599d84b19c354d26dcf475ab4be775b991ac97884791017b12471000def05bb77bfe9c3a97d44ef78c9449f12daf6e25b61ab1a281

它使用 Rijndael 加密,ECB 模式(电子密码本),密钥:Pas5pr@se,128 位密钥大小和块大小。

我遇到的问题是我似乎无法做到这一点,有人帮我解决这个问题吗?

4

3 回答 3

7

这是我的一个网站目前正在使用的 Rijndael 加密的实现。看看这是否能解决问题:

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

namespace CMS.Core.Domain
{
    /// <summary>
    /// Summary description for EncryptionManager
    /// </summary>
    public static class EncryptionManager
    {
        public static string EncryptRijndael(string value, string encryptionKey) {
            try {
                var key = Encoding.UTF8.GetBytes(encryptionKey); //must be 16 chars
                var rijndael = new RijndaelManaged {
                    BlockSize = 128,
                    IV = key,
                    KeySize = 128,
                    Key = key
                };

                var transform = rijndael.CreateEncryptor();
                using (var ms = new MemoryStream()) {
                    using (var cs = new CryptoStream(ms, transform, CryptoStreamMode.Write)) {
                        byte[] buffer = Encoding.UTF8.GetBytes(value);

                        cs.Write(buffer, 0, buffer.Length);
                        cs.FlushFinalBlock();
                        cs.Close();
                    }
                    ms.Close();
                    return Convert.ToBase64String(ms.ToArray());
                }
            }
            catch {
                return string.Empty;
            }
        }

        public static string DecryptRijndael(string value, string encryptionKey)
        {
            try
            {
                var key = Encoding.UTF8.GetBytes(encryptionKey); //must be 16 chars
                var rijndael = new RijndaelManaged
                                               {
                                                   BlockSize = 128,
                                                   IV = key,
                                                   KeySize = 128,
                                                   Key = key
                                               };

                var buffer = Convert.FromBase64String(value);
                var transform = rijndael.CreateDecryptor();
                string decrypted;
                using (var ms = new MemoryStream())
                {
                    using (var cs = new CryptoStream(ms, transform, CryptoStreamMode.Write))
                    {
                        cs.Write(buffer, 0, buffer.Length);
                        cs.FlushFinalBlock();
                        decrypted = Encoding.UTF8.GetString(ms.ToArray());
                        cs.Close();
                    }
                    ms.Close();
                }

                return decrypted;
            }
            catch
            {
                return null;
            }
        }
    }
}

更新

我刚刚注意到您输入的一件事是您的加密密钥只有 9 个字符,而我上面的代码需要 16 个字符的密钥。我不确定这是否是 Rijndael 加密算法的硬性要求,但上述代码不适用于不完全是 16 个字符的加密密钥。

于 2010-04-19T16:56:09.830 回答
0

我遇到了这个链接,它解决了 AES Rijndael 加密的 C# 和 ActionScript

http://ryoushin.com/cmerighi/en-us/42,2007-03-02/AES-Rijndael_with_ActionScript_and_ASP_Net.aspx

于 2010-04-23T11:08:37.453 回答
0

你可以试试这个 Rijndael 的包装器,因为它可能是 IV 或密码填充的问题(我很想知道它是否不起作用)

于 2010-04-23T11:13:33.360 回答