|
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 17
|
|
Написать AES, шифрования любого файла .exe.22.06.2015, 12:44. Показов 6160. Ответов 20
Метки нет (Все метки)
Есть задача написать AES, который будет зашифровывать и расшифровывать любой файл .exe. Как лучше открывать этот файл, если нужно считывать по 16 байт? В моей программе сначала неадекватно работало с переносом на новую строку (после расшифровывался какой-то бред вместо текста), а теперь не работает совсем. Само шифрование/расшифрование написано вроде правильно, было протестировано на строке байтов.
0
|
|
| 22.06.2015, 12:44 | |
|
Ответы с готовыми решениями:
20
Алгоритм шифрования из exe файла Получить версию любого .exe файла |
|
2924 / 1274 / 114
Регистрация: 27.05.2008
Сообщений: 3,465
|
|
| 22.06.2015, 12:52 | |
|
В бинарном режиме, понятное дело. Приведи код, глянем......
0
|
|
|
Модератор
8978 / 6744 / 921
Регистрация: 14.02.2011
Сообщений: 23,852
|
|
| 22.06.2015, 13:00 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 17
|
|
| 22.06.2015, 13:43 [ТС] | |
|
Просто изначально программу сказали написать для текстовых файлов, поэтому тесты проходили на текстовых файлах. Но оно даже txt не шифрует нормально
0
|
|
|
1394 / 1023 / 325
Регистрация: 28.07.2012
Сообщений: 2,813
|
|||
| 22.06.2015, 13:52 | |||
|
Если бы AES изначально работал для случая бинарных файлов, то и с текстами он бы справлялся на ура и не было бы проблемы с переносами строки. Так что тебе нужно: 1) Открывать файлы в бинарном виде. 2) Читать и писать при помощи методов read() write() для fstream, или fread() и fwrite() для случая сишного FILE *. Добавлено через 2 минуты
0
|
|||
|
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 17
|
||||||
| 22.06.2015, 14:02 [ТС] | ||||||
|
Оно - шифрование.
Не строка, а массив байтов.
0
|
||||||
|
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 17
|
|
| 22.06.2015, 14:11 [ТС] | |
|
Cipher просто функция шифрования. На вход подаётся двухмерный массив из байтов, поэтому сначала из c1 распихиваем значения в массив.
0
|
|
|
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 17
|
|||||||||||
| 22.06.2015, 16:28 [ТС] | |||||||||||
|
Я открываю любой файл, например, так
0
|
|||||||||||
|
Модератор
8978 / 6744 / 921
Регистрация: 14.02.2011
Сообщений: 23,852
|
||
| 22.06.2015, 17:18 | ||
0
|
||
|
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 17
|
|
| 22.06.2015, 17:30 [ТС] | |
|
ValeryS, спасибо)
0
|
|
|
1394 / 1023 / 325
Регистрация: 28.07.2012
Сообщений: 2,813
|
|||||
| 22.06.2015, 21:42 | |||||
|
Эта функция прочитает максимум 17 символов, до первого перевода строки. Не стоит говорить, что после кодирования этого перевода строки уже не будет. И условно существующий ваш декодер будет декодировать нечто не то. Строки 10-13: Это что за шаманство такое? stat2[i / N][i % N] = (byte)c1[i]; Стоит учесть, что из файла может прочитать меньше, чем 16 байт. Тогда в массиве stat2 будет лежать непонятный хлам.
0
|
|||||
|
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 17
|
||||||
| 22.06.2015, 22:18 [ТС] | ||||||
|
Да, ошибка, должно быть не 17, а 16 (изначально так и было сделано, но считывало из текстовых файлов на один символ меньше, поэтому 17). И в stat2 будут лежать считанные байты, которые после идут на вход в функцию шифрования. Вот этот код работает нормально, зашифровывает, а аналогичный расшифровывает. h это размер в байтах файла, который нужно зашифровать. P.S. Код кривой, но умею писать только так
0
|
||||||
|
1394 / 1023 / 325
Регистрация: 28.07.2012
Сообщений: 2,813
|
||||
| 22.06.2015, 23:04 | ||||
|
И такой подход приведет к тому, что размер расшифрованного файла будет отличаться от изначального.
0
|
||||
|
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 17
|
|
| 22.06.2015, 23:54 [ТС] | |
|
В смысле, утечка памяти?
Он там заполняет не нулями, я понимаю, но это в принципе ничего не меняет. Тут же существует проблема последнего блока текста (если количество байт не делится на 16). Вот последний блок заполняется этими 48 сначала, а потом идут байты из файла exe. Там в любом случае последний блок нужно чем-то дозаполнять, в моём случае это такое число. При расшифровании эта куча 48-ок всё равно отбрасывается.
0
|
|
|
1394 / 1023 / 325
Регистрация: 28.07.2012
Сообщений: 2,813
|
|||
| 23.06.2015, 00:06 | |||
|
Не стоит исключать, что в конце файла могут быть свои 48-ки. Тут либо нужно данные шифровать вместе с их размером, либо вводить стоп-символы.
0
|
|||
|
0 / 0 / 0
Регистрация: 03.06.2015
Сообщений: 17
|
|
| 23.06.2015, 00:42 [ТС] | |
|
Изначальное количество байт у нас есть, берем по модулю 16 = остаток, который нам нужен. Остальное откидываем. Разве нет?
0
|
|
|
1394 / 1023 / 325
Регистрация: 28.07.2012
Сообщений: 2,813
|
||
| 23.06.2015, 01:02 | ||
|
что дешифровку можно выполнить, имея на руках только сам зашифрованный файл и ключ. Так что хорошая реализация подразумевает два модуля. Первый с помощью ключа шифрует файл, второй с помощью этого же ключа дешифрует ранее зашифрованный файл. И работать они должны независимо друг от друга. Частой проверкой работы алгоритма является внесение ручных изменений в зашифрованный файл и проверка того, что получается при дешировке. Если при приеме у вас не так, то можно ничего больше не делать.
0
|
||
| 23.06.2015, 01:02 | |
|
Помогаю со студенческими работами здесь
20
стандарт шифрования AES
Получение ключа для AES шифрования из строки Ошибка при открытии любого приложения вследствие удаления файла StormII.exe Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|