Cryptography-with-python-rsa-cipher-encryption

提供:Dev Guides
移動先:案内検索

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)

2つのパラメーターは必須です: message および pub_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)