RSA 암호 암호화

이 장에서는 RSA 암호 암호화의 다양한 구현과 이와 관련된 기능에 중점을 둘 것입니다. RSA 암호 알고리즘 구현을 구현하기 위해이 Python 파일을 참조하거나 포함 할 수 있습니다.

암호화 알고리즘에 포함 된 모듈은 다음과 같습니다.

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"

더 나은 보안을 위해 해시 값을 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)

암호화의 경우 RSA 알고리즘을 따르는 다음 기능이 사용됩니다.

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

두 가지 매개 변수는 필수입니다. messagepub_key공개 키를 나타냅니다. 암호화에는 공개 키가 사용되고 암호 해독에는 개인 키가 사용됩니다.

암호화 절차를위한 전체 프로그램은 다음과 같습니다.

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)