"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 고급 암호화 기술로 데이터 보호를 강화하는 방법은 무엇입니까?

고급 암호화 기술로 데이터 보호를 강화하는 방법은 무엇입니까?

2024-11-08에 게시됨
검색:305

How to Enhance Data Protection with Advanced Encryption Techniques?

대칭 키 암호화: Fernet

Python은 안전하고 모범적인 암호화 체계인 Fernet을 제공하는 강력한 암호화 라이브러리를 보유하고 있습니다. Fernet은 AES CBC 암호화, HMAC 서명, 버전 및 타임스탬프 정보를 사용하여 데이터를 보호합니다. Fernet.generate_key()를 사용하여 키를 생성하는 것이 좋습니다.

from cryptography.fernet import Fernet

key = Fernet.generate_key()
message = 'John Doe'
token = Fernet(key).encrypt(message.encode())
decrypted_message = Fernet(key).decrypt(token).decode()  # 'John Doe'

Alternatives:

Obscuring: 모호함이 필요하면 base64 인코딩으로 충분할 수 있습니다. URL 안전을 위해 urlsafe_b64encode()를 사용하세요.

import base64

obscured_message = base64.urlsafe_b64encode(b'Hello world!')  # b'eNrzSM3...='

무결성 전용: HMAC는 암호화 없이 데이터 무결성 보장을 제공할 수 있습니다.

import hmac
import hashlib

key = secrets.token_bytes(32)
signature = hmac.new(key, b'Data', hashlib.sha256).digest()

AES-GCM 암호화: AES-GCM은 패딩 없이 암호화와 무결성을 모두 제공합니다.

import base64

key = secrets.token_bytes(32)
ciphertext = aes_gcm_encrypt(b'Data', key)  # base64-encoded ciphertext and tag
decrypted_data = aes_gcm_decrypt(ciphertext, key)  # b'Data'

다른 접근 방식:

AES CFB: 패딩이 없는 CBC와 유사합니다.

import base64

key = secrets.token_bytes(32)
ciphertext = aes_cfb_encrypt(b'Data', key)  # base64-encoded ciphertext and IV
decrypted_data = aes_cfb_decrypt(ciphertext, key)  # b'Data'

AES ECB: 주의: 안전하지 않습니다! 실제 애플리케이션에는 권장되지 않습니다.

import base64

key = secrets.token_bytes(32)
ciphertext = aes_ecb_encrypt(b'Data', key)  # base64-encoded ciphertext
decrypted_data = aes_ecb_decrypt(ciphertext, key)  # b'Data'
릴리스 선언문 이 글은 1729591101에서 재인쇄되었습니다. 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3