Skip to content

Latest commit

 

History

History
61 lines (54 loc) · 2.01 KB

File metadata and controls

61 lines (54 loc) · 2.01 KB

CLI Image Encryption / Decryption Tool

Overview

ImgVault - Image Encryption and Decryption Tool, is designed to securely encrypt and decrypt images using a method based on the XOR operation. The project employs Cipher Block Chaining (CBC) mode, where each pixel's color value is XORed with both a key and an initial value (IV) to enhance security. The IV is updated dynamically as the encryption progresses, adding an extra layer of complexity. Additionally, you have included the concept of rounds, allowing for repeated encryption/decryption passes over the image for stronger protection. The tool supports both encryption and decryption through command-line arguments.

Setup

  1. Clone the repository:
git clone https://github.com/AmalRitessh/CLI-Image-Encryption-Decryption-Tool.git
  1. Navigate to the project directory:
cd ImgVault
  1. Install dependencies:
pip install -r requirements.txt

Usage

  1. Encrypting Images.
# The format to pass variables
python3 ImgVault.py -e <path-to-img> <key> <initial-value> <no-of-rounds>
# Example usage
python3 ImgVault.py -e cat.jpg 4630 5734 13
# Example usage
python3 ImgVault.py --encrypt cat.jpg 4630 5734 13
  1. Decrypting Images.
# The format to pass variables
python3 ImgVault.py -d <path-to-img> <key> <initial-value> <no-of-rounds>
# Example usage
python3 ImgVault.py -d image_enc.png 4630 5734 13
# Example usage
python3 ImgVault.py --decrypt image_enc.png 4630 5734 13
  1. Help
python3 ImgVault.py -h
python3 ImgVault.py --help

Example Output

Original Image Encrypted Image Decrypted Image
Original Encrypted Decrypted