Fake Encryption
The Encryption
The source script encrypts the image file which contains the flag using Data Encryption Standard (DES) ECB MODE as follows:
Splits data into the size of a single DES chunk (i.e. 8 bytes)
Encrypts the Orignal Flag image
Uses the first block as a seed to generate the random sequence
Shuffles the original data chunks of the image and saves it
Encrypts the shuffled data
ECB MODE "lacks diffusion" i.e. in ECB mode, encryption of identical plaintext blocks results in identical ciphertext blocks.
The Attack
With this info, we can retrieve the flag if we map the ciphertext blocks to the plaintext blocks and then try to unshuffle the plaintext data. As the flag was a PNG image, the first block(that's used as the seed) is the PNG file Signature(hex value = 89 50 4E 47 0D 0A 1A 0A
) which remains the same for every PNG file.
Thus, we can set this seed and generate a sample sequence and collect the shuffled indices. Then we can use this to recreate the flag from the shuffled chunks.
Solve Script: solve.py
Flag: wormcon{ECB_lacks_diffiusion}
Last updated