Chiffrement RSA

Dans ce chapitre, nous nous concentrerons sur différentes implémentations du chiffrement RSA et les fonctions impliquées pour celui-ci. Vous pouvez faire référence ou inclure ce fichier python pour implémenter l'implémentation de l'algorithme de chiffrement RSA.

Les modules inclus pour l'algorithme de chiffrement sont les suivants -

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"

Nous avons initialisé la valeur de hachage en SHA-256 pour une meilleure sécurité. Nous utiliserons une fonction pour générer de nouvelles clés ou une paire de clés publique et privée en utilisant le code suivant.

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)

Pour le cryptage, la fonction suivante est utilisée qui suit l'algorithme RSA -

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

Deux paramètres sont obligatoires: message et pub_keyqui fait référence à la clé publique. Une clé publique est utilisée pour le chiffrement et une clé privée est utilisée pour le déchiffrement.

Le programme complet pour la procédure de cryptage est mentionné ci-dessous -

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)