Recently i am interested in crypto. so I enjoyed this challenge a lot.
Look at the problem below
data:image/s3,"s3://crabby-images/52add/52addb2006100e0952a4dbce45784d5c49ceeffa" alt=""
data:image/s3,"s3://crabby-images/43d89/43d89757bd548b088174b5236e777ca2ffd763f1" alt=""
enc27.py
If you look at enc27.py, you can see it's xor encryption. and 24 byte block padding.
data:image/s3,"s3://crabby-images/6cc75/6cc7572d110a04ed12faf86464d910b298282b75" alt=""
png file is encrypted with key( original_png ^ key ) And as you know, A xor A = 0. so if we know original_png. then we can find key. I checked png sample files and file signature to figure out key. and enc27.py is padding 24 bit message block and xoring with key i guess key length is 24. So if I xor between png file signature and encrypted png, it would reveals padding value..
Do it.
import itertools
def xoring(m1,m2):
return ''.join(chr(ord(a)^ord(b)) for a,b in zip(m1,m2))
def decrypt(enc, key):
key = itertools.cycle(key)
dec = ''.join(chr(ord(a) ^ ord(b)) for a,b in zip(key,enc))
return dec
def main():
f = open("BITSCTFfullhd.png","r")
f2 = open("tmp.png","wb")
buf = f.read()
#png signature
png = "\x89\x50\x4E\x47\x0D\x0A\x1A\x0A\x00"
key = xoring(buf[:9],png)
#unkown key
key += "A"*(24-9)
dec = decrypt(buf,key)
f2.write(dec)
f.close()
f2.close()
if __name__ == '__main__':
main()
data:image/s3,"s3://crabby-images/6ff05/6ff05bec8ec5fe429d13def38c3d397f474ba960" alt=""
we know 9 bytes key. And first 9 byte from each 24 byte of block was decrypted. You can see that "\x13" is repeated 4 times. Yeah~ padding value is "\x13". "\x13"*(15)^enc[-15:] would reveal left key values.
import itertools
def xoring(m1,m2):
return ''.join(chr(ord(a)^ord(b)) for a,b in zip(m1,m2))
def decrypt(enc, key):
key = itertools.cycle(key)
dec = ''.join(chr(ord(a) ^ ord(b)) for a,b in zip(key,enc))
return dec
def main():
f = open("BITSCTFfullhd.png","r")
f2 = open("tmp.png","wb")
buf = f.read()
#png signature
png = "\x89\x50\x4E\x47\x0D\x0A\x1A\x0A\x00"
key = xoring(buf[:9],png)
key += xoring(buf[-15:], "\x13"*15)
dec = decrypt(buf,key)
f2.write(dec)
f.close()
f2.close()
if __name__ == '__main__':
main()
data:image/s3,"s3://crabby-images/56516/56516664c7c71e4ff17f5b9d1a796f3c3fd557f3" alt=""
flag is BITSCTF{p_en_gee}