Шифрование Rijndael из Action Script для C # - PullRequest
2 голосов
/ 19 апреля 2010

Я пытаюсь разделить шифрование между Action Script и C #

Моя задача - расшифровать следующее сообщение в C #

f1ca22a365ba54c005c3eb599d84b19c354d26dcf475ab4be775b991ac97884791017b12471000def05bb77bfe9c3a97d44ef78c9449f12daf6e25b61ab1a281

Используется шифрование Rijndael, режим ECB (электронная кодовая книга), ключ: Pas5pr @ se, размер ключа 128 бит и размер блока.

У меня проблема в том, что я не могу это сделать, кто-нибудь мне в этом поможет?

Ответы [ 3 ]

7 голосов
/ 19 апреля 2010

Это реализация Rijndael Encryption, которую в настоящее время использует один из моих веб-сайтов. Посмотрим, поможет ли это:

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 символов.

0 голосов
/ 23 апреля 2010

Вы можете попробовать эту оболочку для Rijndael, так как это может быть проблема с IV или дополнением пароля (мне было бы интересно узнать, не работает ли оно)

0 голосов
/ 23 апреля 2010

Я натолкнулся на эту ссылку, которая касается как C #, так и ActionScript для шифрования AES Rijndael

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

...