Cifrado de cifrado RSA

En este capítulo, nos centraremos en diferentes implementaciones del cifrado de cifrado RSA y las funciones involucradas para el mismo. Puede consultar o incluir este archivo de Python para implementar la implementación del algoritmo de cifrado RSA.

Los módulos incluidos para el algoritmo de cifrado son los siguientes:

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"

Hemos inicializado el valor hash como SHA-256 para mejorar la seguridad. Usaremos una función para generar nuevas claves o un par de claves públicas y privadas usando el siguiente código.

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)

Para el cifrado, se utiliza la siguiente función que sigue el algoritmo RSA:

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

Dos parámetros son obligatorios: message y pub_keyque se refiere a la clave pública. Se utiliza una clave pública para el cifrado y una clave privada para el descifrado.

El programa completo para el procedimiento de cifrado se menciona a continuación:

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)