Тройное шифрование DES - PullRequest
5 голосов
/ 09 августа 2011

Обратите внимание, что у меня возникла проблема с ключом размер .Сначала, основываясь на комментариях, включенных в код ниже, я решил, что мой ключ должен быть 24 байта (192 бита).Это не сработало, поэтому я дал 16, 32 и 8-байтовым клавишам выстрел - похоже, ничего не получалось.Под «не работает» я подразумеваю, что после того, как мой текст был зашифрован и расшифрован, он не будет иметь того же значения, что и мой исходный текст.

Пример:

Оригинальный текст: 'Example test this should work '

Зашифрованный текст: ¸ ¹pÕô6

Расшифрованный текст: 'Example '

Вотдве функции, которые я использую (функции шифрования / дешифрования).Также я расскажу, как я вызываю каждую функцию.

        // 168-bit (three-key) 3DES (Triple-DES) encrypt a single 8-byte block (ECB mode)
        // plain-text should be 8-bytes, key should be 24 bytes.
        public byte[] TripleDesEncryptOneBlock(byte[] plainText, byte[] key)
        {
            // Create a new 3DES key.
            TripleDESCryptoServiceProvider des = new TripleDESCryptoServiceProvider();

            // Set the KeySize = 192 for 168-bit DES encryption.
            // The msb of each byte is a parity bit, so the key length is actually 168 bits.

            des.KeySize = 192;
            des.Key = key;
            des.Mode = CipherMode.ECB;
            des.Padding = PaddingMode.None;

            ICryptoTransform ic = des.CreateEncryptor();

            byte[] enc = ic.TransformFinalBlock(plainText, 0, 8);

            return enc;
        }

        public byte[] TripleDesDecryptBlock(byte[] plainText, byte[] key)
        {
            // Create a new 3DES key.
            TripleDESCryptoServiceProvider des = new TripleDESCryptoServiceProvider();

            // Set the KeySize = 192 for 168-bit DES encryption.
            // The msb of each byte is a parity bit, so the key length is actually 168 bits.
            des.KeySize = 192;
            des.Key = key;
            des.Mode = CipherMode.ECB;
            des.Padding = PaddingMode.None;

            ICryptoTransform ic = des.CreateDecryptor();

            byte[] dec = ic.TransformFinalBlock(plainText, 0, 8);

            return dec;
        }

// Encrypt Text
textBox5.Text = ByteToString(TripleDesEncryptOneBlock(StringToByte(textBox5.Text), StringToByte("1 2 3 4 5 6 7 8 9 1 1 2 ")));

// Decrypt Text
textBox5.Text = ByteToString(TripleDesDecryptBlock(StringToByte(textBox5.Text), StringToByte("1 2 3 4 5 6 7 8 9 1 1 2 ")));

Спасибо за любую помощь,

Эван

Ответы [ 2 ]

2 голосов
/ 12 декабря 2012

Используйте это:

byte[] enc = ic.TransformFinalBlock(plainText, 0, plainText.Length);

Я надеюсь, что он зашифрует / расшифрует всю вашу строку. Также вам не нужно будет вызывать этот метод несколько раз

2 голосов
/ 09 августа 2011

Подсказка в названии функции, которую вы используете: TripleDesEncryptOneBlock

Этот метод шифрует только один блок входной строки (8 байт или 64 бита).Чтобы зашифровать всю строку, вам нужно связать несколько вызовов этого метода.

...