天天看點

aes加密算法python語言實作_Python AES加密子產品用法分析

本文執行個體講述了Python AES加密子產品用法。分享給大家供大家參考,具體如下:

AES是新的一種加密子產品。在上次介紹過在C語言中如何來OpenSSL中的DES。這次我們來看看Python自帶的庫如何來使用AES來加解密。其實二者的原理還是非常像,隻是說在python中來做這個事情會比C語言要簡單點,但是比起C#/Java還是有點點啰嗦。在C#/JAVA這種語言中,對于加密的源資料的處理,padding一般都會有完整的實作。我在上次C語言中也處理過這個問題。在python庫中,也是需要自己來處理這個。

from Crypto.Cipher import AES

# padding算法

BS = 16

pad = lambda s: s + (BS - len(s) % BS) * chr(0)

unpad = lambda s : s[0:-ord(s[-1])]

# 将字元串轉換成二進制的buff塊

def parse_hex(hex_str):

l=int(math.ceil(len(hex_str)/2))

buf=''

for i in range(0,l):

s=hex_str[(i*2):((i+1)*2)]

buf=buf+chr(int(s,16))

return buf

# 解析加密的key

key=parse_hex("68b329da9893e34099c7d8ad5cb9c940")

iv=parse_hex("68b329da9893e34099c7d8ad5cb9c940")

# 建立一個AES的對象

aes_obj = AES.new(key, AES.MODE_CBC,iv)

# 做位元組對齊

padding_zero=pad(raw_buf)

# 開始加密

encrypt_buf=aes_obj.encrypt(padding_zero)

# 解密

buff=aes_obj.decrypt(encrypt_buf)

這個代碼中padding寫的還是非常漂亮的。如果在C裡面實作這個,還需要啰嗦寫不少。

PS:關于加密解密感興趣的朋友還可以參考本站線上工具:

線上MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:http://tools.jb51.net/password/hash_md5_sha

希望本文所述對大家Python程式設計有所幫助。