Skip to main content

A pure Python Steganography module.

Project description

Stegano

Workflow

Stegano, a pure Python Steganography module.

Steganography is the art and science of writing hidden messages in such a way that no one, apart from the sender and intended recipient, suspects the existence of the message, a form of security through obscurity. Consequently, functions provided by Stegano only hide messages, without encryption. Steganography is often used with cryptography.

Installation

$ poetry install stegano

You will be able to use Stegano in your Python programs.

If you only want to install Stegano as a command line tool:

$ pipx install stegano

pipx installs scripts (system wide available) provided by Python packages into separate virtualenvs to shield them from your system and each other.

Usage

A tutorial is available.

Use Stegano as a library in your Python program

If you want to use Stegano in your Python program you just have to import the appropriate steganography technique. For example:

>>> from stegano import lsb
>>> secret = lsb.hide("./tests/sample-files/Lenna.png", "Hello World")
>>> secret.save("./Lenna-secret.png")
>>>
>>> clear_message = lsb.reveal("./Lenna-secret.png")

Use Stegano as a command line tool

Hide and reveal a message

$ stegano-lsb hide -i ./tests/sample-files/Lenna.png -m "Secret Message" -o Lena1.png
$ stegano-lsb reveal -i Lena1.png
Secret Message

Hide the message with the Sieve of Eratosthenes

$ stegano-lsb hide -i ./tests/sample-files/Lenna.png -m 'Secret Message' --generator eratosthenes -o Lena2.png

The message will be scattered in the picture, following a set described by the Sieve of Eratosthenes. Other sets are available. You can also use your own generators.

This will make a steganalysis more complicated.

Running the tests

$ python -m unittest discover -v

Running the static type checker:

$ mypy stegano

Contributions

Contributions are welcome. If you want to contribute to Stegano I highly recommend you to install it in a Python virtual environment with poetry.

Donations

If you wish and if you like Stegano, you can donate via GitHub Sponsors:

GitHub Sponsors

or with Bitcoin to this address:
bc1q56u6sj7cvlwu58v5lemljcvkh7v2gc3tv8mj0e

Thank you !

License

This software is licensed under GNU General Public License version 3

Copyright (C) 2010-2026 Cédric Bonhomme

For more information, the list of authors and contributors is available.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

stegano-2.1.0.tar.gz (36.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

stegano-2.1.0-py3-none-any.whl (37.4 kB view details)

Uploaded Python 3

File details

Details for the file stegano-2.1.0.tar.gz.

File metadata

  • Download URL: stegano-2.1.0.tar.gz
  • Upload date:
  • Size: 36.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for stegano-2.1.0.tar.gz
Algorithm Hash digest
SHA256 61a49af950d4ecfffb5b28d7ed9fd3405f9ee2c1dc7add4e7a7c04e3694f87a3
MD5 23906224ccb3ee791ce164708d1318da
BLAKE2b-256 c07298107635b0020bb3b349c404b020ac7e1e722f4024bfaec9cac83e45e349

See more details on using hashes here.

Provenance

The following attestation bundles were made for stegano-2.1.0.tar.gz:

Publisher: release.yml on cedricbonhomme/Stegano

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file stegano-2.1.0-py3-none-any.whl.

File metadata

  • Download URL: stegano-2.1.0-py3-none-any.whl
  • Upload date:
  • Size: 37.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for stegano-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d64d0a87ab93bdad92c126707287d884f0bec71182f495e0f4424d8d89cb68f2
MD5 2929c701d48084dedca577f5d7bd93f2
BLAKE2b-256 3a0b2dac8c15b7806fde4558fa78b61a0065b30e0955090aae55d08137da5f08

See more details on using hashes here.

Provenance

The following attestation bundles were made for stegano-2.1.0-py3-none-any.whl:

Publisher: release.yml on cedricbonhomme/Stegano

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page