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가 필요한 상황은 생각보다 많이 오니 저장!
반응형
'프로그래밍' 카테고리의 다른 글
Visual Studio / x64 아키텍쳐에서 어셈블리어를 사용하기 | 소스코드정렬 (0) | 2018.02.27 |
---|---|
[Python] DES 예제 (0) | 2018.02.06 |
[kernel] PsSetLoadImageNotifyRoutine 와 PsSetCreateProcessNotifyRoutine (0) | 2018.02.01 |
메모리 에디터 개발 (0) | 2017.02.24 |
Chrome Extension 만드는 법 (0) | 2016.01.26 |
댓글