Crittografia crittografia RSA

In questo capitolo, ci concentreremo su diverse implementazioni della crittografia di cifratura RSA e sulle funzioni coinvolte per la stessa. Puoi fare riferimento o includere questo file python per implementare l'implementazione dell'algoritmo di cifratura RSA.

I moduli inclusi per l'algoritmo di crittografia sono i seguenti:

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"

Abbiamo inizializzato il valore hash come SHA-256 per una migliore sicurezza. Useremo una funzione per generare nuove chiavi o una coppia di chiavi pubbliche e private utilizzando il codice seguente.

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)

Per la crittografia, viene utilizzata la seguente funzione che segue l'algoritmo RSA:

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

Due parametri sono obbligatori: message e pub_keyche si riferisce alla chiave pubblica. Una chiave pubblica viene utilizzata per la crittografia e una chiave privata viene utilizzata per la decrittografia.

Il programma completo per la procedura di crittografia è menzionato di seguito:

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)