python의 aes 암호화 코드 공유
학부 때 DES 암호화 알고리즘을 만들어서 컴퓨터 파일을 암호화했는데 DES 암호화 알고리즘은 현재 기본적으로 폐기된 상태이기 때문에 지금은 좀 더 고급스럽게 해 보려고 합니다.
DES 암호화 알고리즘은 3DES 암호화 알고리즘으로 발전할 수 있는데 나중에 AES 암호화 알고리즘으로 업그레이드되어 키의 길이를 늘렸고 폭력적인 해독의 어려움을 증가시켰다.
이번에 Python을 사용하여 AES 암호화 복호화 수행
import hashlib
from Crypto.Cipher import AES
import base64
class prpcrypt():
def __init__(self,key):
self.key = key # python3 AES , bytearray , encode (linux )
IV = 16 * '\x00'
self.iv=IV.encode("utf-8")
self.mode = AES.MODE_CBC
self.BS = AES.block_size
self.pad = lambda s: s + (self.BS - len(s) % self.BS) * chr(self.BS - len(s) % self.BS)
self.unpad = lambda s: s[0:-ord(s[-1])]
#
def encrypt(self, text):
text = self.pad(text).encode("utf-8")
cryptor = AES.new(self.key, self.mode, self.iv)
# AES-128 (CBC )
ciphertext = cryptor.encrypt(text)
# base64
return base64.b64encode(bytes(ciphertext))
#
def decrypt(self, text):
# base64
text = base64.b64decode(text)
cryptor = AES.new(self.key, self.mode, self.iv)
# CBC
plain_text = cryptor.decrypt(text)
# strip()
return self.unpad(bytes.decode(plain_text).rstrip('\0')) # ???
def gen_binsha(data):
shavalue = hashlib.sha256()
shavalue.update(data)
return shavalue.digest()
if __name__ == '__main__':
key='78f40cecf89'
key=gen_binsha(key.encode('utf-8'))
pc = prpcrypt(key=key) # iv
text='qwerqwerkkk12345'
e = pc.encrypt(text) #
d = pc.decrypt(e) #
print(" :%s" % e)
print(" :%s"% d)
print(" :%s"% len(d))
이상은python의 aes 암호화 코드에 대한 상세한 내용을 공유하는 것입니다.python의 aes 암호화 코드에 대한 더 많은 자료는 저희 다른 관련 글을 주목해 주십시오!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
로마 숫자를 정수로 또는 그 반대로 변환그 중 하나는 로마 숫자를 정수로 변환하는 함수를 만드는 것이었고 두 번째는 그 반대를 수행하는 함수를 만드는 것이었습니다. 문자만 포함합니다'I', 'V', 'X', 'L', 'C', 'D', 'M' ; 문자열이 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.