Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176

Установка 128bit-ключ для AES

06.12.2016, 22:04. Показов 3656. Ответов 8

Студворк — интернет-сервис помощи студентам
При попытке установить AES ключ более 32 bit, появляется ошибка. :-\
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Security.Cryptography;
using System.IO;
 
namespace Test
{
    class Program
    {
        static void Main(string[] args)
        {
            AesCryptoServiceProvider aes = new AesCryptoServiceProvider();
            byte[] key = ASCIIEncoding.ASCII.GetBytes("1234567812345678123456781234567812345678123456781234567812345678");
            aes.Key = key;
        }
    }
}
Этот код УЖЕ выдаёт ошибку, но ведь в AES ключ должен быть 128/256/512, а не 16/32...
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.12.2016, 22:04
Ответы с готовыми решениями:

Как правильно перевести ключ и вектор в байты Aes
Всем здрасте. Прошу прощения если такая тема уже была, но я толком ответа не нашел. Такой вопрос: у меня есть информация, ключ и вектор....

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

AES известна исходная строка и результат, можно получить ключ?
Здравствуйте. Есть исходная строка 128бит и зашифрованная. Известно, что ключ 128бит. Есть способ вычислить ключ, кроме брута?

8
Эксперт .NET
 Аватар для insite2012
5548 / 4311 / 1218
Регистрация: 12.10.2013
Сообщений: 12,371
Записей в блоге: 2
06.12.2016, 22:28
Цитата Сообщение от Mikha Mikhin Посмотреть сообщение
в AES ключ должен быть 128/256/512
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Security.Cryptography;
 
namespace ConsoleApplication7 {
    class Program {
        static void Main(string[] args) {
            byte[] bytes = ASCIIEncoding.ASCII.GetBytes("1234567812345678123456781234567812345678123456781234567812345678");
            byte[] key = Enumerable.Range(0, 16).Select(b => (byte)b).ToArray();
            Aes aes = Aes.Create();
            aes.Key = key;
            foreach (var keySize in aes.LegalKeySizes) {
                Console.WriteLine("Min: {0}, Max: {1}", keySize.MinSize, keySize.MaxSize);
            }
            Console.ReadLine();
        }
    }
}
0
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176
06.12.2016, 22:35  [ТС]
Если я не ошибаюсь, тут берётся только первые 16 символов ключа. Тогда какой смысл в этом вообще?
0
тыжПрограммист
 Аватар для LonerZzz
330 / 144 / 44
Регистрация: 21.04.2014
Сообщений: 638
06.12.2016, 23:10
Цитата Сообщение от Mikha Mikhin Посмотреть сообщение
Этот код УЖЕ выдаёт ошибку, но ведь в AES ключ должен быть 128/256/512, а не 16/32...
хешируй ключ с помощью MD5. Он как раз таки будет равен 128 битам. И используй хэш сумму в качестве ключа для шифрования
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18298 / 14222 / 5368
Регистрация: 17.03.2014
Сообщений: 28,898
Записей в блоге: 1
06.12.2016, 23:34
Лучший ответ Сообщение было отмечено Mikha Mikhin как решение

Решение

Mikha Mikhin, длины ключей указываются в битах, а работаем мы обычно с байтами. То есть длина ключа = длина массива byte[] * 8. Ты берешь строку из 64 символов, получаешь из них массив из 64 элементов. То есть пытаешься использовать ключ длиной 64 * 8 = 512 битов что превышает максимально разрешенный размер в два раза.
2
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176
07.12.2016, 10:14  [ТС]
Цитата Сообщение от OwenGlendower Посмотреть сообщение
Mikha Mikhin, длины ключей указываются в битах, а работаем мы обычно с байтами. То есть длина ключа = длина массива byte[] * 8. Ты берешь строку из 64 символов, получаешь из них массив из 64 элементов. То есть пытаешься использовать ключ длиной 64 * 8 = 512 битов что превышает максимально разрешенный размер в два раза.
То есть максимальный ключ всё-равно равен 32 символам?
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18298 / 14222 / 5368
Регистрация: 17.03.2014
Сообщений: 28,898
Записей в блоге: 1
07.12.2016, 10:41
Mikha Mikhin, максимальная длина ключа составляет 256 битов что равно 32 байтам и что НЕ равно 32 символам потому что один символ не равен одному байту в общем случае.
0
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176
07.12.2016, 10:47  [ТС]
Цитата Сообщение от OwenGlendower Посмотреть сообщение
Mikha Mikhin, максимальная длина ключа составляет 256 битов что равно 32 байтам и что НЕ равно 32 символам потому что один символ не равен одному байту в общем случае.
Тогда какое максимальное кол-во символов можно использовать в ключе для алгоритма AES?
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18298 / 14222 / 5368
Регистрация: 17.03.2014
Сообщений: 28,898
Записей в блоге: 1
07.12.2016, 10:50
Mikha Mikhin, в ASCII или других однобайтовых кодировках - 32.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.12.2016, 10:50
Помогаю со студенческими работами здесь

Radeon X1650 Pro (DDR2 512mb 128bit Sapphire) или Radeon HD2600 XT (DDR3 256mb 128bit Sapphire)
Народ подскажите мне лучше !!! Radeon X1650 Pro (DDR2 512mb 128bit Sapphire) или Radeon HD2600 XT (DDR3 256mb 128bit Sapphire) если не...

Ключ к платформе 8.1. Установка 8.2
Здравствуйте. Есть диск и ключ лицензии платформы 8.1. Нужно поставить 8.2. Т.е. можно просто установить тех. платформу 1С 8.2,...

Установка XP с операционной системы, не знаю ключ
Установка XP с операционной системы, не зная ключ (Ошибся в заголовке) Нужно срочно переустановить Windows 64 одному юзеру , Но есть...

AES 192 и AES 256
Добрый день! Возможно ли в Java сделать шифрование с помощью AES 256- или 192-битными ключами? Единственное условие, что мешает мне...

AES для Android
Всем привет! Я столкнулся с проблемой написания программы шифрования стандарту AES для мобильной платформы Android. Подскажыте какие...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru