Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/calderwhite/gif-msg

Hide 127 bytes in a gif without touching any pixels or colors
https://github.com/calderwhite/gif-msg

cryptography gifs steganography steganography-algorithms

Last synced: 3 months ago
JSON representation

Hide 127 bytes in a gif without touching any pixels or colors

Awesome Lists containing this project

README

        

# gif-msg

gif-msg hides a 128 byte message in a gif while keeping the pixel values identical.
Can you figure out how I did it?

gif's popular usage in messaging apps allow them to blend into conversations naturally.
This way users can send secret (potentially encrypted) messages to eachother without it
being obvious to a 3rd party. This method of steganography is also largely applicable on message forums.

## Installation

Pillow's gif encoder does not support lossless compression, so gifsicle is used
to re-encode the gif such that its file size does not increase.

```bash
# Install dependancies
pip3 install -r requirements.txt
sudo apt install gifsicle

# Clone module
git clone https://github.com/CalderWhite/gif-msg/
cd gif-msg
git submodule update --init --recursive
```

## Usage

Please use the [Latest Stable Release](https://github.com/CalderWhite/gif-msg/releases/latest) and note that the semantic versioning indicates when changes will not be backwards compatible (so the major release must match if you are to exchange gifs with another version).

```
usage: gif_msg.py [-h] [--key KEY] [--compress]
command infile [outfile] [body]

Encode/Decode 128 bytes into a gif file.

positional arguments:
command The command to be run (encode/decode)
infile The input gif.
outfile The outfile gif. (applicable for encode)
body The message to be encoded. (applicable for encode)

optional arguments:
-h, --help show this help message and exit
--key KEY If given a key, AES will be used to encrypt/decrypt the message
body.
--compress If supplied, smaz will be used to compress the body. NOTE: This
is only effective with language, and binary data is best left
uncompressed

```

## Known Bugs

- Greyscale gifs are not currently supported.
- Gifs with <256 colors can only hold n//2 bytes, where n=number of colors
- Gifs with duplicate colors in their color palette

**Note**: If there color white (`0xFFFFFF`) is in the color palette and the image has transparency, this will create a duplicate color error since PIL overwrites what is at the transparent index in the palette as `0xFFFFFF`)