RSA-Verschlüsselung

In diesem Kapitel konzentrieren wir uns auf die unterschiedliche Implementierung der RSA-Verschlüsselung und die damit verbundenen Funktionen. Sie können diese Python-Datei zum Implementieren der Implementierung des RSA-Verschlüsselungsalgorithmus referenzieren oder einschließen.

Die für den Verschlüsselungsalgorithmus enthaltenen Module lauten wie folgt:

from Crypto.PublicKey import RSA
from Crypto.Cipher import PKCS1_OAEP
from Crypto.Signature import PKCS1_v1_5
from Crypto.Hash import SHA512, SHA384, SHA256, SHA, MD5
from Crypto import Random
from base64 import b64encode, b64decode
hash = "SHA-256"

Wir haben den Hashwert aus Sicherheitsgründen als SHA-256 initialisiert. Wir werden eine Funktion verwenden, um neue Schlüssel oder ein Paar von öffentlichen und privaten Schlüsseln unter Verwendung des folgenden Codes zu generieren.

def newkeys(keysize):
   random_generator = Random.new().read
   key = RSA.generate(keysize, random_generator)
   private, public = key, key.publickey()
   return public, private
def importKey(externKey):
   return RSA.importKey(externKey)

Für die Verschlüsselung wird die folgende Funktion verwendet, die dem RSA-Algorithmus folgt:

def encrypt(message, pub_key):
   cipher = PKCS1_OAEP.new(pub_key)
   return cipher.encrypt(message)

Zwei Parameter sind obligatorisch: message und pub_keyDies bezieht sich auf den öffentlichen Schlüssel. Ein öffentlicher Schlüssel wird zur Verschlüsselung und ein privater Schlüssel zur Entschlüsselung verwendet.

Das vollständige Programm für die Verschlüsselung ist unten aufgeführt -

from Crypto.PublicKey import RSA
from Crypto.Cipher import PKCS1_OAEP
from Crypto.Signature import PKCS1_v1_5
from Crypto.Hash import SHA512, SHA384, SHA256, SHA, MD5
from Crypto import Random
from base64 import b64encode, b64decode
hash = "SHA-256"

def newkeys(keysize):
   random_generator = Random.new().read
   key = RSA.generate(keysize, random_generator)
   private, public = key, key.publickey()
   return public, private

def importKey(externKey):
   return RSA.importKey(externKey)

def getpublickey(priv_key):
   return priv_key.publickey()

def encrypt(message, pub_key):
   cipher = PKCS1_OAEP.new(pub_key)
   return cipher.encrypt(message)