Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Conversation

ace-dent
Copy link

Smashed the 334 bytes original down to a slim 60 bytes, by hand crafting a v1.x BMP file.

All versions of the BMP format begin with a basic 14 byte file header.
Next is the secondary DIB header; 12 bytes is the smallest possible (IBM OS/2 – v1.x BMP files).

Avoiding the more ‘advanced’ / modern bitmap file formats has a big impact for small files, while still widely supported and well documented.

Sources:
http://www.fileformat.info/format/os2bmp/egff.htm
http://www.fileformat.info/format/bmp/egff.htm
http://en.wikipedia.org/wiki/BMP_file_format
https://msdn.microsoft.com/en-us/library/dd183372(v=vs.85).aspx
https://msdn.microsoft.com/en-us/library/dd183374(v=vs.85).aspx

Smashed the 334 bytes original down to a slim 60 bytes, by hand crafting a v1.x BMP file.

All versions of the BMP format begin with a basic 14 byte file header.
Next is the secondary DIB header; 12 bytes is the smallest possible (IBM OS/2 – v1.x BMP files).

Avoiding the more ‘advanced’ / modern bitmap file formats has a big impact for small files, while still widely supported and well documented.

Sources:
http://www.fileformat.info/format/os2bmp/egff.htm
http://www.fileformat.info/format/bmp/egff.htm
http://en.wikipedia.org/wiki/BMP_file_format
https://msdn.microsoft.com/en-us/library/dd183372(v=vs.85).aspx
https://msdn.microsoft.com/en-us/library/dd183374(v=vs.85).aspx
@ace-dent
Copy link
Author

The committed version is ‘clean’, zero bit padded -totally vanilla.


But since each row has to be padded to a 4 byte boundary, we actually have 19 bits of padding (32 bits - 13 bits).
We might replace the last 2 bytes per row with a hidden image!


Changing ‘bcWidth’ at address 18 from 0x0D (decimal 13) to 0x20 (decimal 32), reveals our steganography…


Or, we might choose to hide some other data in those bytes :-)


@ace-dent
Copy link
Author

Bump @angea :-)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant