Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/18: Рейтинг темы: голосов - 18, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 12.05.2015
Сообщений: 15

AES шифрование (длинный текст)

17.05.2015, 00:39. Показов 3829. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Не пойму в чем проблема, шифрование на коротких предложениях работает нормально. Как только загружаю длинный текст, его шифрует (как подозреваю не полностью) и расшифровывает не полностью добавляя немного мусора на конец текста.
Посмотрите пожалуйста исходник, может я что-то где-то просмотрел. В AES.cpp уверен что все хорошо. Текст для теста находиться там же (TEXT_FOR_TEST).

AES.zip
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
17.05.2015, 00:39
Ответы с готовыми решениями:

Шифрование по алгоритму AES в С++ Builder
Делаю программу для шифрования текстовых файлов. Уже реализовал шифрование Цезаря и XOR. Теперь хочу добавить возможность шифрования по...

Зашифровать и расшифровать текст алгоритмом AES
Помогите зашифровать и розшифровать текст в C++ Builder 6 алгоритмом AES!!! Спасибо!

Текст из RichEdit в поле Access типа "Длинный текст"
Друзья, подскажите, пожалуйста, как правильно добавлять текст из RichEdit в поле Access типа "Длинный текст"? Обновляю базу...

9
place status here
 Аватар для gunslinger
3190 / 2227 / 640
Регистрация: 20.07.2013
Сообщений: 6,023
17.05.2015, 01:28
В AES.cpp на строках
C++
1
 (u32 *)rk += 8;
выдает (XE5)
Code
1
2
[bcc32 Error] AES.cpp(839): E2277 Lvalue required
[bcc32 Error] AES.cpp(944): E2277 Lvalue required
0
 Аватар для kzru_hunter
1124 / 795 / 101
Регистрация: 01.02.2011
Сообщений: 1,887
Записей в блоге: 1
17.05.2015, 06:39
Лучший ответ Сообщение было отмечено hopov как решение

Решение

Класс THexString умеет принимать на вход только строку AnsiString, которая является нультерминированной, из-за чего он не распознаёт текст после символа '\0'. Поэтому можно сделать так:
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
void __fastcall TForm1::Button1Click(TObject *Sender)
{
 
        unsigned int len = Memo1->Text.Length();
        byte *buf = EncryptBuffer(Edit1->Text.c_str(), Edit1->Text.Length(), Memo1->Text.c_str(), len);
 
        // буфер в Hex
        String HexString = "";
        for ( int i = 0; i < len; i++ ) // len теперь имеет другое значение, возвращенное функцией EncryptBuffer
        {
                HexString += IntToHex(buf[i], 2) + " ";
        }
 
        Memo2->Text = HexString;
 
        delete[] buf; // буфер, который возвращает EncryptBuffer и DecryptBuffer, нужно освобождать
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Button2Click(TObject *Sender)
{
        unsigned int iLen = Memo2->Text.Length();
 
        THexString text;
        text.AsHexString = Memo2->Text;
 
        char *buf = DecryptBuffer(Edit1->Text.c_str(), Edit1->Text.Length(), text.AsCharString.c_str(), iLen);
 
        Memo1->Text = buf;
 
        delete[] buf; // буфер, который возвращает EncryptBuffer и DecryptBuffer, нужно освобождать
 
}
1
0 / 0 / 0
Регистрация: 12.05.2015
Сообщений: 15
17.05.2015, 12:39  [ТС]
Спасибо большое! Не пойму, почему тогда остальные алгоритмы отлично работают с THexString. Может лучше добавить буфер и к ним ?
0
0 / 0 / 0
Регистрация: 12.05.2015
Сообщений: 15
17.05.2015, 12:54  [ТС]
Перенес алгоритм в общую программу, теперь при расшифровке длинного текста получаю



memcpy(pt,pBuf+i,iLen);

Хм, если нажать ОК и опять в программе нажать расшифровать, то текст расшифрует нормально.
0
 Аватар для kzru_hunter
1124 / 795 / 101
Регистрация: 01.02.2011
Сообщений: 1,887
Записей в блоге: 1
17.05.2015, 13:07
Цитата Сообщение от hopov Посмотреть сообщение
Не пойму, почему тогда остальные алгоритмы отлично работают с THexString.
Насчет остальных алгоритмов без понятия, но в этом случае EncryptBuffer возвращает строку, в которой могут быть нули, и соответственно размер этой строки. Если эту строку загнать в THexString, то он соответственно проигнорирует всё, что находится после первого встретившегося нуля, потому как принимает на вход тип AnsiString. По-хорошему, он должен принимать на вход char* и len (размер строки).
Цитата Сообщение от hopov Посмотреть сообщение
Перенес алгоритм в общую программу, теперь при расшифровке длинного текста получаю
без понятия, нужно видеть весь код
0
 Аватар для SergeyKu
108 / 49 / 26
Регистрация: 24.10.2012
Сообщений: 56
17.05.2015, 13:38
Цитата Сообщение от kzru_hunter Посмотреть сообщение
строку AnsiString, которая является нультерминированной
Цитата Сообщение от kzru_hunter Посмотреть сообщение
проигнорирует всё, что находится после первого встретившегося нуля, потому как принимает на вход тип AnsiString
AnsiString может содержать сколько угодно нулей
0
 Аватар для kzru_hunter
1124 / 795 / 101
Регистрация: 01.02.2011
Сообщений: 1,887
Записей в блоге: 1
17.05.2015, 13:46
Цитата Сообщение от SergeyKu Посмотреть сообщение
AnsiString может содержать сколько угодно нулей
может, но он не предназначен для использования в нем нулей
0
 Аватар для Access12
19 / 19 / 4
Регистрация: 28.04.2013
Сообщений: 139
17.05.2015, 13:48
Символы в нем нумеруются с 1, а не с 0, так что как написано выше, после 0 , будет игнор
1
0 / 0 / 0
Регистрация: 12.05.2015
Сообщений: 15
17.05.2015, 15:37  [ТС]
Проблема с ошибкой решилась сама собой после компиляции проекта как релиз.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
17.05.2015, 15:37
Помогаю со студенческими работами здесь

Aes шифрование
Привет, нужна помощь, есть программная реализация aes, помогите определить в каком режиме шифрования она выполнена , если таковой вообще...

Aes шифрование
Подскажите, где можно найти реализацию данного алгоритма шифрования?

AES шифрование
Ребят помогите разобраться с расшифровкой текста из фаила. На клиенте текст криптуется средствами aes шифрования, далее перегоняется в...

AES шифрование
Видел кучу тем на эту тему, но так для себя решения и не нашел, здесь реализация заточена на текст, но мне надо шифровать массивы байт и...

Шифрование AES
Прочитал статью на одном из сайтов и услышал такую тему, что такие алгоритмы, как AES-28; AES-192 и AES-256 используют ключи и длины...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru