欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python AES加密模塊用法分析

 更新時(shí)間:2017年05月22日 10:45:13   作者:erlang_hell  
這篇文章主要介紹了Python AES加密模塊用法,結(jié)合具體實(shí)例形式分析了AES加密模塊的相關(guān)使用技巧與注意事項(xiàng),需要的朋友可以參考下

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

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

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])]
# 將字符串轉(zhuǎn)換成二進(jìn)制的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")
# 新建一個(gè)AES的對(duì)象
aes_obj = AES.new(key, AES.MODE_CBC,iv)
# 做字節(jié)對(duì)齊
padding_zero=pad(raw_buf)
# 開始加密
encrypt_buf=aes_obj.encrypt(padding_zero)
# 解密
buff=aes_obj.decrypt(encrypt_buf)

這個(gè)代碼中padding寫的還是非常漂亮的。如果在C里面實(shí)現(xiàn)這個(gè),還需要啰嗦寫不少。

PS:關(guān)于加密解密感興趣的朋友還可以參考本站在線工具:

文字在線加密解密工具(包含AES、DES、RC4等):
http://tools.jb51.net/password/txt_encode

MD5在線加密工具:
http://tools.jb51.net/password/CreateMD5Password

在線散列/哈希算法加密工具:
http://tools.jb51.net/password/hash_encrypt

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

在線sha1/sha224/sha256/sha384/sha512加密工具:
http://tools.jb51.net/password/sha_encode

更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python編碼操作技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python Socket編程技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論