45 lines
983 B
ReStructuredText
45 lines
983 B
ReStructuredText
Symmetric Key Algorithms
|
|
========================
|
|
|
|
.. module:: wolfcrypt.ciphers
|
|
|
|
**Symmetric key algorithms** are encryption algorithms that use the **same
|
|
cryptographic keys** for both encryption and decryption of data.
|
|
This operation is also known as **Symmetric Key Encryption**.
|
|
|
|
``wolfcrypt`` provides access to the following **Symmetric Key Ciphers**:
|
|
|
|
Symmetric Key Encryption Classes
|
|
--------------------------------
|
|
|
|
Interface
|
|
~~~~~~~~~
|
|
|
|
All **Symmetric Key Ciphers** available in this module implements the following
|
|
interface:
|
|
|
|
.. autoclass:: _Cipher
|
|
:members:
|
|
|
|
Classes
|
|
~~~~~~~
|
|
|
|
.. autoclass:: Aes
|
|
|
|
.. autoclass:: Des3
|
|
|
|
|
|
Example
|
|
-------
|
|
|
|
.. doctest::
|
|
|
|
>>> from wolfcrypt.ciphers import Aes, MODE_CBC
|
|
>>>
|
|
>>> cipher = Aes(b'0123456789abcdef', MODE_CBC, b'1234567890abcdef')
|
|
>>> ciphertext = cipher.encrypt('now is the time ')
|
|
>>> ciphertext
|
|
b'\x95\x94\x92W_B\x81S,\xcc\x9dFw\xa23\xcb'
|
|
>>> cipher.decrypt(ciphertext)
|
|
b'now is the time '
|