Well hidden message - Insignificant blue
Flag: HACKDAY{s73@M_$7@tion_4CcE5S}
Challenge
Description
On a USB key marked with the seal of the Black Mist, a mysterious film was discovered. This film, that you are watching from the EIGHTH ROW of seats in the Cogswell Halls cinema, shows apparently innocuous scènes. But according to rumors, it is not just a simple video. Data would have been compressed and hidden there…
Format: You need to find bytes of a zip archive containing the flag HACKDAY{FLAG} SHA256: f950cd9690cefea88deb08af718c8933ded7641758ed145724d7812ee79102d0
https://challenges.s3.rbx.io.cloud.ovh.net/challenges/well-hidden-message.avi
Ce challenge tourne sur un docker et n'est pas disponible
Solution
On parle de Insignificant blue. Il faut le comprendre comme LSB sur le channel bleu. Il y a également l'indice EIGHT ROW. Il faut faire un LSB sur le bleu sur les 8 premières lignes.
Maintenant, on n'a pas une image, mais une vidéo. Il suffit donc d'appliquer cette méthode pour chaque frame de la vidéo.
On sait que l'on doit récupérer un ZIP, il faut donc détecter la fin de celui-ci pour éviter de récupérer trop de données. Pour ça, un petit schéma de la structure s'impose :

Un fichier ZIP termine par la signature PK\x05\x06 puis par un commentaire de taille variable. Pour connaître cette taille, il faut que 16 bytes après la signature de fin. On peut donc analyse les données que l'on récupère pour détecter la fin du ZIP.
Mis à jour