项目作者: dotX12

项目描述 :
🔒 Alguns is a symmetric encryption method that contains 2 keys. Uses 128-bit AES in CBC mode and PKCS7 padding with the replacement of letters with random values.
高级语言: Python
项目地址: git://github.com/dotX12/AlgunsCrypt.git
创建时间: 2020-05-18T22:09:56Z
项目社区:https://github.com/dotX12/AlgunsCrypt

开源协议:BSD 2-Clause "Simplified" License

下载


Alguns

Alguns is a symmetric encryption method that contains 2 keys, without which decryption of the message is impossible.

Alguns also uses 128-bit AES in CBC mode and PKCS7 padding.

Letters and symbols are encrypted using the replacement method generate_replacement. A replacement character for a letter consists of [randomSymbol, randomNumber(0,99), randomSymbol, randomNumber(0,99)].
A Alguns key as returned by the generate_key actually contains two 16-byte keys:
A signing key used to sign the HMAC.

A private key used by the encryption.
These two values are concatenated to form a 32 byte value. This 32 byte key is then encoded using Base64 encoding. This encodes the binary quantity as string of ASCII characters. The variant of Base64 used is URL and filename safe, meaning that it doesn’t contain any characters that aren’t permitted in a URL or a valid filename in any major operating system.


Supported Languages:

  • Russian
  • English

Installation

The installation method for this module is shown below.

pip3 install alguns


How generate keys?
  1. key = Alguns.generate_key()
  2. replacement = Alguns.generate_replacement()
  3. # Put this somewhere safe!
How to encrypt a message?
  1. mykey = # My key that I created earlier.
  2. myreplacement = # My replacement that I created earlier.
  3. al = Alguns(key=mykey, replacement=myreplacement)
  4. msgcrypt = al.encrypt('Hellow it is my message! Привет, это мое сообщение...')
  5. print(msgcrypt)
  6. # gAAAAABewxb_nE1mbHgN7ma79_XAbh68hLblIFdX3czIEmUDCSFWxMXTTEdIU5...
How to decrypt a message?

```python
al = Alguns(key=mykey, replacement=myreplacement)
msgdecrypt = al.decrypt(‘gAAAAABewxb_nE1mbHgN7ma79_XAbh68hLblIFdX3czIEmUDCSFWxMXTTEdIU5…’)
print(msgdecrypt)

Hellow it’s my message! Привет, это мое сообщение…