Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/adrg/lsbsteg
Embeds messages into images using the Least Significant Bit algorithm
https://github.com/adrg/lsbsteg
algorithm criptography image-processing pycrypto python steganography
Last synced: about 2 months ago
JSON representation
Embeds messages into images using the Least Significant Bit algorithm
- Host: GitHub
- URL: https://github.com/adrg/lsbsteg
- Owner: adrg
- License: mit
- Created: 2015-08-12T20:19:23.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2023-01-04T23:10:31.000Z (about 2 years ago)
- Last Synced: 2024-05-21T02:13:42.111Z (8 months ago)
- Topics: algorithm, criptography, image-processing, pycrypto, python, steganography
- Language: Python
- Size: 3.91 KB
- Stars: 11
- Watchers: 3
- Forks: 8
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
lsbsteg
=======
[![License: MIT](http://img.shields.io/badge/license-MIT-red.svg?style=flat-square)](http://opensource.org/licenses/MIT)lsbsteg is a small Python 3 application which embeds text messages into images
using the Least Significant Bit steganographic algorithm.The basic idea of the algorithm is to take each individual bit of the message
and set it as the least significant bit of each component of each pixel of
the image. Usually, a pixel has Red, Green, Blue components and sometimes
an Alpha component. Because the values of these components change very little
if the least significant bit is changed, the color difference is not
particularly noticeable, if at all.## Requirements
- **pillow**
- **pycrypto** (optional)If you are on a Linux system, you most likely have the required dependencies
already. If you don't, they can be easily installed using pip.```bash
sudo pip3 install -U pillow
sudo pip3 install -U pycrypto
```If you get 'decoder not available' errors when running the application make
sure you have all the pillow dependencies installed:```bash
sudo apt-get install libjpeg-dev zlib1g-dev
sudo pip3 install -I pillow
```## Usage
```bash
lsbsteg.py [-h] [-v] {embed,extract} ...
```The application can both embed messages into images and extract them.
### Embedding messages into images
```bash
lsbsteg.py embed [-h] [-o OUT] [-k KEY] IMAGE MESSAGEpositional arguments:
IMAGE source image
MESSAGE message to embed into the imageoptional arguments:
-o OUT, --output OUT generated output image containing the specified message
-k KEY, --key KEY key used to encrypt the message before embedding it
```* Note: if the output image is not provided, the message is saved in the input image.
**Without encryption**
```bash
lsbsteg.py embed -o output.png input.png "message to embed"
```**With encryption**
```bash
lsbsteg.py embed -o output.png -k passphraze input.png "message to embed"
```Because JPEG uses lossy compression, it cannot be specified as an output image
format. Instead, it can be converted to a lossless compression format like
PNG even if the input image is a JPEG image.```bash
lsbsteg.py embed -o output.png input.jpg "the message you want to embed"
```* Note: if pycrypto is not installed, the application does not have encryption support.
### Extracting messages from images
```bash
lsbsteg.py extract [-h] [-k KEY] IMAGEpositional arguments:
IMAGE image containing messageoptional arguments:
-k KEY, --key KEY key to decrypt the extracted message
```**Without encryption**
```bash
lsbsteg.py extract output.png
```**With encryption**
```bash
lsbsteg.py extract -k passphraze output.png
```## License
Copyright (c) 2015 Adrian-George Bostan.This project is licensed under the [MIT license](http://opensource.org/licenses/MIT). See LICENSE for more details.