Criptografia de criptografia RSA

Neste capítulo, vamos nos concentrar em diferentes implementações de criptografia de criptografia RSA e nas funções envolvidas na mesma. Você pode consultar ou incluir este arquivo python para implementar a implementação do algoritmo de criptografia RSA.

Os módulos incluídos para o algoritmo de criptografia são os seguintes -

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"

Inicializamos o valor de hash como SHA-256 para fins de segurança melhor. Usaremos uma função para gerar novas chaves ou um par de chaves pública e privada usando o código a seguir.

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 criptografia, é usada a seguinte função que segue o algoritmo RSA -

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

Dois parâmetros são obrigatórios: message e pub_keyque se refere à chave pública. Uma chave pública é usada para criptografar e uma chave privada é usada para descriptografar.

O programa completo para o procedimento de criptografia é mencionado abaixo -

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)