>백엔드 개발 >파이썬 튜토리얼 >Python에서 안전한 AES-256 암호화 및 암호 해독을 구현하는 방법은 무엇입니까?

Python에서 안전한 AES-256 암호화 및 암호 해독을 구현하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-21 07:17:09254검색

How to Implement Secure AES-256 Encryption and Decryption in Python?

PyCrypto AES-256을 사용한 암호화 및 복호화

메시지와 키에 대해 작동하는 PyCrypto를 사용하여 효율적인 암호화 및 복호화 기능을 구성하려면, 특정 고려 사항을 고려해야합니다

키 정렬 및 엔트로피:

제공된 키의 길이가 예상대로인지 확인하는 것이 중요합니다. PyCrypto에서는 길이가 32바이트인 강력한 키를 사용할 것을 제안합니다. 이를 달성하려면 SHA-256으로 키를 해시하고 결과 다이제스트를 암호화 키로 사용하십시오.

암호화 모드:

AES 암호화의 경우 암호 블록 체인( CBC) 모드가 일반적으로 사용됩니다. 연속적인 암호 텍스트 블록을 초기화 벡터(IV)와 결합하여 보안을 강화합니다.

초기화 벡터(IV):

IV는 임의의 값입니다. 암호화하는 동안 암호문 앞에 추가됩니다. 이는 암호화된 각 메시지의 고유성을 보장하고 공격자가 암호문 내의 패턴을 활용하는 것을 방지합니다. 암호화 및 복호화에 서로 다른 IV를 제공할 수 있지만 각 암호화 작업에 고유한 IV를 사용하는 것이 중요합니다.

구현:

아래 샘플 구현에는 이러한 고려 사항이 포함되어 있습니다. :

import base64
import hashlib
from Crypto import Random
from Crypto.Cipher import AES

class AESCipher(object):

    def __init__(self, key):
        self.bs = AES.block_size
        self.key = hashlib.sha256(key.encode()).digest()

    def encrypt(self, raw):
        raw = self._pad(raw)
        iv = Random.new().read(AES.block_size)
        cipher = AES.new(self.key, AES.MODE_CBC, iv)
        return base64.b64encode(iv + cipher.encrypt(raw.encode()))

    def decrypt(self, enc):
        enc = base64.b64decode(enc)
        iv = enc[:AES.block_size]
        cipher = AES.new(self.key, AES.MODE_CBC, iv)
        return AESCipher._unpad(cipher.decrypt(enc[AES.block_size:])).decode('utf-8')

    def _pad(self, s):
        return s + (self.bs - len(s) % self.bs) * chr(self.bs - len(s) % self.bs)

    @staticmethod
    def _unpad(s):
        return s[:-ord(s[len(s)-1:])]

이 구현은 키가 32바이트로 안전하게 해시되고 CBC를 사용하도록 보장합니다. 암호화 모드를 선택하고 암호화 중에 임의의 IV를 생성합니다. 복호화 기능은 암호문에서 IV를 복구하고 이를 사용하여 암호화 프로세스를 역전시킵니다.

위 내용은 Python에서 안전한 AES-256 암호화 및 암호 해독을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.