Дешифруйте текстовый файл обратно в изображение, используя AES.

Вопрос или проблема

Я пытаюсь расшифровать текстовый файл, и информация, которую я имею на данный момент, заключается в том, что использовался режим CBC и метод шифрования AES, а также мне был дан секретный ключ vanessa.

Вот оригинальный файл encrypted_file

  • Сначала я выполнил эту команду для декодирования в base64
    base64 -d encryption_result.txt > decoded_encrypted_data.bin
    

    и затем я продолжил выполнять эту команду:

    openssl aes-256-cbc -md md5 -in decoded_encrypted_data.bin -out decimage
    
  • Теперь у меня есть файл с именем decimage, который я сделал дамп в шестнадцатеричном формате, и я заметил, что он содержит соль, но с этого момента я застрял:
    $ hexdump -C decimage | head -n 20
    00000000  53 61 6c 74 65 64 5f 5f  1e 46 5b 61 2c 83 16 11  |Salted__.F[a,...|
    00000010  3d 6e 3f 8e 62 3b 91 f8  38 97 35 c9 3f 8b 93 66  |=n?.b;..8.5.?..f|
    00000020  85 c5 26 74 1a c8 47 02  03 51 75 8d 93 db 5a c9  |..&t..G..Qu...Z.|
    00000030  8a fa 48 b0 02 cc 1a 88  3a b7 7e 01 ab 69 dc 4c  |..H.....:.~..i.L|
    00000040  37 19 fe f3 07 1f 27 57  0c f2 2f b8 56 90 b3 ea  |7.....'W../.V...|
    00000050  7f 0c 69 35 2b bb 55 04  e3 6f 1c 7a 7c b7 cb af  |..i5+.U..o.z|...|
    00000060  46 4c 94 3f 05 1f ee 22  3a 00 4d 99 fc 1a 1d a6  |FL.?...":.M.....|
    00000070  89 34 fd af 78 8e de e6  98 df a0 62 03 f9 7a ab  |.4..x......b..z.|
    00000080  7e 09 87 21 c6 0c 3a 0c  d7 f8 fe c6 0c 1a 7d 2a  |~..!..:.......}*|
    00000090  55 d7 54 e4 4e 37 92 d5  d9 3a 72 cf 09 6c 2f f0  |U.T.N7...:r..l/.|
    000000a0  a3 20 25 d4 94 2f c2 88  6f d8 4d 35 0c 2b c6 f4  |. %../..o.M5.+..|
    000000b0  09 38 8f 76 b3 ae 83 85  29 9e 4d ef c7 a4 ab 6b  |.8.v....).M....k|
    000000c0  e2 fc d1 e4 f9 7e 25 1f  ca c1 c0 cc 15 3e d3 56  |.....~%......>.V|
    000000d0  f7 c5 a4 66 f2 37 c0 5f  0c 16 ec ba 06 78 7c 07  |...f.7._.....x|.|
    000000e0  23 22 8c d6 c5 79 bc 51  b0 39 47 de f3 c8 ec 34  |#"...y.Q.9G....4|
    000000f0  b0 90 bb d0 09 ff e0 b7  43 3a ce 59 47 47 13 87  |........C:.YGG..|
    00000100  7e c1 1f 12 7d 5f f2 22  92 4b ac 07 cb 81 b9 2c  |~...}_.".K.....,|
    00000110  d0 26 31 26 fd 06 5c a5  00 09 ba e9 2c d0 53 9d  |.&1&..\.....,.S.|
    00000120  33 eb e7 cf 73 b1 da b3  52 0e 70 62 ef 7f 3a ef  |3...s...R.pb..:.|
    00000130  00 5c c6 2b 74 21 bb 14  5c 49 cf 8c a7 e8 69 d9  |.\.+t!..\I....i.|
    

Я также пытался получить ключ из vanessa, но это тоже не похоже на то, что работает. Как мне подойти к этому?

man openssl-enc – полезный справочник. В частности,

-d Расшифровать входные данные.

Также, чтобы сэкономить вам шаг,

-a Обработать данные в формате Base64. Это значит, что если шифрование происходит, то данные кодируются в base64 после шифрования. Если установлено декодирование, то входные данные декодируются из base64 перед расшифровкой.

Ответ или решение

Чтобы расшифровать текстовый файл, который был зашифрован с использованием AES в режиме CBC, необходимо следовать нескольким четким шагам. Я пошагово опишу процесс, принимая во внимание ваши ранее выполненные действия и предоставленную информацию о формате файла и методах, используемых для шифрования.

Шаг 1: Подготовка и прогрузка файла

Убедитесь, что ваш файл с зашифрованным текстом успешно скачан и доступен для работы. Судя по вашему описанию, вы уже успешно декодировали файл из Base64, используя команду:

base64 -d encryption_result.txt > decoded_encrypted_data.bin

Теперь у вас есть файл decoded_encrypted_data.bin, который, как вы предположили, содержит зашифрованные данные.

Шаг 2: Уточнение метода шифрования

Дальше вы упомянули, что ваш файл decimage кажется "солью", что указывает на то, что при шифровании, скорее всего, использовалось дополнение соли (salt), что означает, что данные могут быть зашифрованы по методу OpenSSL, который добавляет префикс "Salted__".

Шаг 3: Извлечение соли и ключа

Для успешно расшифровки вам нужно извлечь соль и сгенерировать ключ из пароля. Давайте начнем с извлечения соли. Соль размещается сразу после заголовка "Salted" и занимает 8 байт. В данном случае в вашем выводе hexdump видно, что данные начинаются с 53 61 6c 74 65 64 5f 5f (что соответствует "Salted"), и следующая последовательность из 8 байт – это соль.

Шаг 4: Генерация ключа из пароля и соли

Чтобы получить ключ из пароля "vanessa" и соли, используется KDF (key derivation function). Ниже приведен пример на Python, который поможет сгенерировать ключ и инициализационный вектор (IV):

import hashlib
from Crypto.Cipher import AES
from Crypto.Util.Padding import unpad

password = b"vanessa"
salt = b'\x1eF[a,83\x16\x11'  # Вставьте здесь вашу соль, извлеченную из файла

# Генерация ключа на основе пароля и соли
key_iv = hashlib.pbkdf2_hmac('sha256', password, salt, 100000, dklen=32 + 16)  # 32 байта для AES + 16 для IV
key, iv = key_iv[:32], key_iv[32:]

# Создание AES-шифра и расшифровка файла
cipher = AES.new(key, AES.MODE_CBC, iv)

with open('decoded_encrypted_data.bin', 'rb') as f:
    ciphertext = f.read()

# Расшифровка и удаление дополнительных байт
plaintext = unpad(cipher.decrypt(ciphertext), AES.block_size)

# Сохранение результата как изображения
with open('decimage.png', 'wb') as img_file:  # Убедитесь, что вы используете правильное расширение
    img_file.write(plaintext)

Шаг 5: Выполнение расшифровки

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

Заключение

Теперь вы знаете процесс расшифровки файла в формате .txt обратно в исходный файл изображения с использованием AES в режиме CBC. Каждый шаг имеет ключевое значение для успешного завершения задачи. Если у вас возникнут дополнительные вопросы или трудности, не стесняйтесь обращаться за помощью.

Оцените материал
Добавить комментарий

Капча загружается...