Skip to main content

A modular Python implementation of AES featuring customizable transformations and comprehensive JSON dataflow logging for cryptographic analysis.

Project description

Warning: This implementation is intended for analysis and educational purpose and should not be used for real-world security.

About

  • Author: shrimp2845
  • Version: 0.1.0
  • License: MIT

A pure Python implementation of the Advanced Encryption Standard (AES) algorithm with support for multiple key sizes, configurable internal transformations, detailed logging, and multiple cipher modes of operation.

Features

  • AES-128/AES-192/AES-256 support
  • ECB/CBC/CTR modes
  • PKCS#7 padding
  • Custom AES transformation configuration
  • Custom S-Box support
  • Encryption/decryption logging

Project Structure


project_AES/
  ├── __init__.py
  ├── block_utils.py
  ├── configs.py
  ├── project_AES.py
  └── aes_core/
      ├── __init__.py
      ├── cipher.py
      ├── core_utils.py
      ├── key_expansion.py
      ├── math_utils.py
      └── round.py

Installation

Requires Python 3.10+

pip install project-aes

or

pip install tqdm
git clone https://github.com/shrimp2845-tw/project_AES.git
cd project_AES

Quick Start

from project_AES import AES
key = b"0123456789abcdef"
plaintext = b"hello world"
cipher = AES(key)
ciphertext = cipher.encrypt(plaintext)
print(ciphertext)

Docs

class initialize
----------------------
from project_AES import AES
aes = AES(key, mode='ECB', config=None)

key -> bytes (16, 24 or 32 bytes)
Required. AES key for 128/192/256-bit encryption.
mode -> str (optional)
Block cipher mode of operation.
Supported: 'ECB', 'CBC', 'CTR'
Default: 'ECB'
config -> AESConfig (optional)
Advanced configuration. Default is AESConfig()


methods
----------------------
encrypt(data: bytes) -> bytes
decrypt(data: bytes) -> bytes
→ Encrypt/decrypt bytes data

encrypt_block(block: bytes) -> bytes
decrypt_block(block: bytes) -> bytes
→ single block (16 bytes) encryption/decryption

Examples

This project includes two example scripts demonstrating different functionalities of the module:

​1.File Cipher: A script for encrypting and decrypting files using AES with various operation modes (ECB, CBC, CTR).

​2.Avalanche Observation: A script to observe the avalanche effect by testing how bit-flips in plaintext affect the ciphertext under different configurations.

Samples

1.File Cipher:

You can try to decrypt these examples by your self

  • hina.png -> encrypt(key=gehenna, mode=ECB) -> hina.bin

  • kayoko.jpg -> encrypt(key=cat, mode=CBC) -> kayoko.bin

  • r18.gif -> encrypt(key=give you up, mode=CTR) -> r18.bin

(I originally wanted to use a picture of Shiina Mahiru, but I couldn’t find any good images under a cc license QAQ)

2.Avalanche Observation:

Alt-text

Disclaimer

This implementation is intended for analysis and educational purposes only.
It does not guarantee cryptographic security or production-level performance efficiency.

Do not use this project in any environment that requires strong security assurances.

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

project_aes-0.1.0.tar.gz (12.1 kB view details)

Uploaded Source

Built Distribution

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

project_aes-0.1.0-py3-none-any.whl (13.0 kB view details)

Uploaded Python 3

File details

Details for the file project_aes-0.1.0.tar.gz.

File metadata

  • Download URL: project_aes-0.1.0.tar.gz
  • Upload date:
  • Size: 12.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for project_aes-0.1.0.tar.gz
Algorithm Hash digest
SHA256 5e5e9a3d089b7ffc7e0ea7e34027bb0ad1c4103cf6d9c0fbc69926cce0bab1af
MD5 cfaa66c2445ab2d6c40e69023e297eff
BLAKE2b-256 74bd99aee64ef145487c0af6506a0e09298cffc1256cc722874992e974a32f8e

See more details on using hashes here.

File details

Details for the file project_aes-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: project_aes-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 13.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for project_aes-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fec108d3971ca95b20a23030085e2b5e87a6faabfc5db949264eb79962851e1f
MD5 9ba934a7c2c3311777f395c7f88422a5
BLAKE2b-256 0b6e52c5ef2baeb7415de9bdf9266a0359367bc6df315578084cb04c14a1b2ff

See more details on using hashes here.

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