본문 바로가기
프로그래밍

[Python] AES 예제

by dladbru 2018. 2. 6.
import base64
from Crypto.Cipher import AES
from Crypto import Random

pad = lambda s: s + (BS - len(s) % BS) * chr(BS - len(s) % BS)
unpad = lambda s : s[:-ord(s[len(s)-1:])]

class AESCipher:
    def __init__( self, key ):
        self.key = key

    def encrypt( self, raw ):
        raw = 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 ) )

    def decrypt( self, enc ):
        enc = base64.b64decode(enc)
        iv = "86afc43868fea6abd40fbf6d5ed50905".decode('hex')
        cipher = AES.new(self.key, AES.MODE_CBC, iv )
        return unpad(cipher.decrypt( enc[16:] ))

fd=open("pattern.bin","rt")
fd2=open("result.txt","wt")

data=fd.read(99999999)
a=AESCipher("68ca4736e2e7472006c9c9cd9bcf5af3".decode('hex'))
fd2.write(a.decrypt(data))




파이썬의 장점은 작은 노력으로 큰 생산성이 아닐까 싶다 


위 예제는 CBC모드의 AES 암복호화 클래스로 가져다가 사용만하면된다. 이미 이해하고 있는 내용으로 AES가 필요한 상황은 생각보다 많이 오니 저장!

반응형

댓글