国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python AES加密模塊用法分析

2020-01-04 17:12:26
字體:
來源:轉載
供稿:網友

本文實例講述了Python AES加密模塊用法。分享給大家供大家參考,具體如下:

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

from Crypto.Cipher import AES# padding算法BS = 16pad = 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# 解析加密的keykey=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里面實現這個,還需要啰嗦寫不少。

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 高碑店市| 潍坊市| 家居| 保靖县| 金塔县| 光泽县| 阿图什市| 北票市| 武胜县| 九江市| 枞阳县| 天津市| 墨江| 奉贤区| 额尔古纳市| 大新县| 井研县| 裕民县| 宁都县| 三穗县| 肇东市| 阳泉市| 正定县| 婺源县| 宁陕县| 江油市| 且末县| 博白县| 泗阳县| 恩施市| 英山县| 屏东县| 海丰县| 蓝田县| 普兰店市| 衡山县| 平罗县| 茂名市| 黔江区| 沛县| 蒙自县|