Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/calderwhite/gif-msg
- Owner: CalderWhite
- License: gpl-3.0
- Created: 2019-12-24T05:13:31.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2022-11-22T07:54:36.000Z (about 2 years ago)
- Last Synced: 2024-10-15T02:09:15.868Z (3 months ago)
- Topics: cryptography, gifs, steganography, steganography-algorithms
- Language: Python
- Homepage: https://calderwhite.medium.com/hiding-data-from-humans-and-computers-in-gif-files-6d95523bf9bb
- Size: 916 KB
- Stars: 33
- Watchers: 4
- Forks: 3
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
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`)