0 / 0 / 0
Регистрация: 03.02.2016
Сообщений: 15
1
.NET 4.x

Как правильно перевести ключ и вектор в байты Aes

04.03.2016, 00:27. Показов 1902. Ответов 5

Всем здрасте. Прошу прощения если такая тема уже была, но я толком ответа не нашел. Такой вопрос: у меня есть информация, ключ и вектор. При шифровке данных ключ и вектор генерируются автоматически Aes классом. Этот ключ и вектор я перегоняю из массива байтов в string с удалением "-", чтобы ключ и вектор выглядели по-человечески и их можно было передавать кому-либо:
C#
1
2
crypt_key.Text = BitConverter.ToString(keyi).Replace("-", String.Empty);
crypt_iv.Text = BitConverter.ToString(ivi).Replace("-", String.Empty);
Это ладно. С этим я еще разобрался. А вот с расшифровкой все обстоит немного иначе... Как мне правильно перевести ключ и вектор в массив байтов, чтобы вот эти самые "-" вернулись на место? Ведь иначе при расшифровке просто напросто будет выбивать ошибку. Как я пытался делать: я переводил в массив байтов и пытался поставить эти "-" через каждые два символа, но так толком у меня ничего и не вышло. Вот как я пытался перевести, но при таком переводе, конечно же, вылетает ошибка, т.к. ключ и вектор уже имеют другую длину:
C#
1
2
byte[] IV = Encoding.UTF8.GetBytes(cbc.Text);
byte[] key = Encoding.UTF8.GetBytes(encryption_key.Text);
Прошу вашей помощи, господа. И извиняюсь за такое странное описание проблемы.
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
04.03.2016, 00:27
Ответы с готовыми решениями:

Как использовать ключ RSA в AES шифрование?
Никак не могу сообразить как мне правильно сделать реализацию чтобы впихнуть ключ RSA 2048 в...

Байты, BufferedImage, AES, GUI
В проекте используются зашифрованные в AES изображения, стоит задача загрузить байты из потока...

Как байты перевести в изображение?
Как байты перевести в изображение?

Как перевести байты в текст
Подскажите как переконвертировать байты из одного файла в текст с сохранением в другом файле

5
Эксперт .NET
6269 / 3897 / 1567
Регистрация: 09.05.2015
Сообщений: 9,188
04.03.2016, 01:49 2
Лучший ответ Сообщение было отмечено loverd97 как решение

Решение

How do you convert Byte Array to Hexadecimal String, and vice versa?
1
Эксперт .NET
5456 / 4229 / 1208
Регистрация: 12.10.2013
Сообщений: 12,223
Записей в блоге: 2
04.03.2016, 10:28 3
Цитата Сообщение от loverd97 Посмотреть сообщение
Прошу вашей помощи, господа.
loverd97, ятд вы сами себе усложняете задачу. Сначала преобразовать в один вид, потом во второй... Зачем? Можно доверить эту работу уже готовым классам, что есть в FCL. Ниже простой пример. Данные для шифровальщика сохраняются в файле, передавайте его пользователю и все.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.IO;
using System.Xml.Serialization;
using System.Runtime.Serialization;
using System.Security.Cryptography;
 
namespace loverd97AESDemo {
    class Program {
        static void Main(string[] args) {
            string text = "Hello World!";
            AESData aesData = new AESData();
            aesData.CreateData();
            SaveAesDataToFile(aesData);
 
            AESData aesFromFile = CreateAesDataFromFile();
 
            byte[] encrypted = EncryptString(text, aesFromFile);
            string outText = DecriptString(encrypted, aesFromFile);
 
            Console.WriteLine(outText);
            Console.ReadLine();
        }
        static string DecriptString(byte[] inData, AESData aesData) {
            using (Aes aes = Aes.Create()) {
                aes.IV = aesData.AesIV;
                aes.Key = aesData.AesKey;
                using (ICryptoTransform decryptor = aes.CreateDecryptor()) {
                    byte[] outData = decryptor.TransformFinalBlock(inData, 0, inData.Length);
                    return Encoding.Default.GetString(outData);
                }
            }
        }
        static byte[] EncryptString(string text, AESData aesData) {
            byte[] outData=null;
            byte[] inData = Encoding.Default.GetBytes(text);
            using (Aes aes = Aes.Create()) {
                aes.IV = aesData.AesIV;
                aes.Key = aesData.AesKey;
                using (ICryptoTransform encryptor = aes.CreateEncryptor()) {
                    outData = encryptor.TransformFinalBlock(inData, 0, inData.Length);
                }
            }
            return outData;
        }
        static AESData CreateAesDataFromFile() {
            XmlSerializer serializer = new XmlSerializer(typeof(AESData));
            using (FileStream fs = File.OpenRead("AES.xml")) {
                AESData temp = (AESData)serializer.Deserialize(fs);
                return temp;
            }
        }
        static void SaveAesDataToFile(AESData aesData) {
            XmlSerializer serializer = new XmlSerializer(typeof(AESData));
            using (FileStream fs = File.OpenWrite("AES.xml")) {
                serializer.Serialize(fs, aesData);
            }
        }
    }
    [Serializable]
    public class AESData {
        public AESData() {    
        }
        public void CreateData() {
            RNGCryptoServiceProvider r = new RNGCryptoServiceProvider();
            AesKey = new byte[0x20];
            AesIV = new byte[0x10];
            r.GetNonZeroBytes(AesKey);
            r.GetNonZeroBytes(AesIV);
        }
        public byte[] AesIV;
        public byte[] AesKey;
    }
}
0
0 / 0 / 0
Регистрация: 03.02.2016
Сообщений: 15
09.03.2016, 01:21  [ТС] 4
insite2012, В том то все и дело, что пользователь должен указать не файл с ключом и вектором, а именно указать их в самой программе. Уже очень долго пытаюсь перевести из string в byte[], но вот именно эти прочерки я никак не могу поставить. Очень прошу помочь с переводом, т.к. шифровка уже написана данным методом.
0
Эксперт .NET
6269 / 3897 / 1567
Регистрация: 09.05.2015
Сообщений: 9,188
09.03.2016, 01:53 5
Цитата Сообщение от loverd97 Посмотреть сообщение
Уже очень долго пытаюсь перевести из string в byte[]
Вам уже дали ссылку на информацию как конвертировать string в byte[] и наоборот. За 5 дней не осилили ее открыть и скопировать оттуда кусок кода?
0
0 / 0 / 0
Регистрация: 03.02.2016
Сообщений: 15
09.03.2016, 02:19  [ТС] 6
Someone007, прошу прощения за свою невнимательность. Проблему решил благодаря ссылке в вашем ответе.
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
09.03.2016, 02:19
Помогаю со студенческими работами здесь

Как перевести байты в формат картинки?
У меня с потока заполняется буфер. Мне с него нужно собрать картинку, чтобы потом ее вставить в...

Как перевести файл в байты и наоборот?
Как перевести файл в байты и наоборот? Файлом может быть картинка или что-то другое. Также и строку.

Как перевести в строку все байты сразу?
у меня есть не много, не мало 3531 штук байтов такого вида 123,213,34,342,324 , их все надо...

Как строку разбитую на байты перевести в нормальное состояние?
%D1%81%D0%BB%D0%BE%D0%B2%D0%BE рак строку разбитую на байты перевести в нормальное состояние...

Установка 128bit-ключ для AES
При попытке установить AES ключ более 32 bit, появляется ошибка. :-\ using System; using...

USB - ключ (токен) AES на VHDL
Здравствуйте. Делаю программно - аппаратную реализацию токена на VHDL задействую криптоалгоритм...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru