Points: 170 Category: Cryptography
My birthday is coming up again, but I want to have a very exclusive party for only the best cryptologists. See if you can solve my challenge, upload 2 valid PDFs that are different but have the same SHA1 hash. They should both have the same 1000 bytes at the end as the original invite. http://mercury.picoctf.net:59127/ invite.pdf
- This isn't REALLY a birthday attack problem
- https://shattered.io/
- The PDFs cannot be the same
- The PDFs must be valid
- The last 1000 bytes of each PDF must match the last 1000 bytes of the original
They sent a website about the first SHA-1 collision files ever made under the second hint. In the website there are two PDFs with the same SHA-1 hash. The question also asks for the last 1000 bytes of the PDFs to be the same as the original. Hashes work dependent on the portion that came before.
If files A and B have the same hash, then C is added to the end of both, then A appended with C will still have the same hash as B appended with C because hashes are only dependent on the part that comes before.
I didn't really want to figure out what the last 1000 bytes of the original file was so I opened the original file with HxD, copied the entire hex content of it, then pasted it at the bottom of both SHA-1 breaking files. PDFs don't read anything after "EOF" (end of file) so this is still a valid file.
These file creations ended up creating this and this which are two very valid PDF files with the last 1000 bytes that are the same as the original and have the same SHA-1 hash.
picoCTF{h4ppy_b1rthd4y_2_m3_96ee9031}