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

python encrypt 實(shí)現(xiàn)AES加密的實(shí)例詳解

 更新時(shí)間:2020年02月20日 15:26:04   作者:眼鏡兒  
在本篇文章里小編給大家分享的是關(guān)于python encrypt 實(shí)現(xiàn)AES加密的實(shí)例內(nèi)容,有興趣的朋友們可以參考下。

AES加密方式有五種ECB, CBC, CTR, CFB, OFB

從安全性角度推薦cbc算法

windows 下安裝 : pip install pycryptodome

linux 下安裝 : pip install pycrypto

cbc加密需要一個(gè)十六位的key 和一個(gè)十六位的iv(偏移量)

ecb加密不需要iv

aes cbc 加密的python實(shí)現(xiàn)

from Crypto.Cipher import AES
from binascii import b2a_hex, a2b_hex

# 如果text不足十六位的倍數(shù)用空格補(bǔ)充
def add_to_16(text):
  if len(text.encode('utf8')) % 16:
    add = 16 - (len(text.encode('utf8')) % 16)
  else:
    add = 0
  text = text + '\0' * add
  return text

# 加密
def encrypt(text):
  key = '9999999999999999'.encode('utf8')
  mode = AES.MODE_CBC
  iv = b'qqqqqqqqqqqqqqqq'
  text = add_to_16(text)
  cryptos = AES.new(key, mode, iv)
  cipher_text = cryptos.encrypt(text)
  # 因?yàn)锳ES加密后的字符串不一定是ascii字符集的,輸出保存可能存在問(wèn)題,所以這里轉(zhuǎn)為16進(jìn)制字符串
  return b2a_hex(cipher_text)

# 解密后去掉空格
def decrypt(text):
  key = '9999999999999999'.encode('utf8')
  mode = AES.MODE_CBC
  iv = b'qqqqqqqqqqqqqqqq'
  cryptos = AES.new(key, mode, iv)
  plain_text = cryptos.decrypt(a2b_hex(text))
  return bytes.decode(plain_text).rstrip('\0')

if __name__ == '__main__':
  a = encrypt('hello')
  b = decrypt(a)
  print('加密', a)
  print('解密', b)

aes ecb加密, 沒(méi)有偏移量iv

from Crypto.Cipher import AES
from binascii import b2a_hex, a2b_hex

# 如果text不足十六位的倍數(shù)用空格補(bǔ)充
def add_to_16(text):
  if len(text.encode('utf8')) % 16:
    add = 16 - (len(text.encode('utf8')) % 16)
  else:
    add = 0
  text = text + '\0' * add
  return text

# 加密
def encrypt(text):
  key = '9999999999999999'.encode('utf8')
  mode = AES.MODE_ECB
  text = add_to_16(text)
  cryptos = AES.new(key, mode)
  cipher_text = cryptos.encrypt(text)
  # 因?yàn)锳ES加密后的字符串不一定是ascii字符集的,輸出保存可能存在問(wèn)題,所以這里轉(zhuǎn)為16進(jìn)制字符串
  return b2a_hex(cipher_text)

# 解密后去掉空格
def decrypt(text):
  key = '9999999999999999'.encode('utf8')
  mode = AES.MODE_ECB
  cryptos = AES.new(key, mode)
  plain_text = cryptos.decrypt(a2b_hex(text))
  return bytes.decode(plain_text).rstrip('\0')

if __name__ == '__main__':
  a = encrypt('hello')
  b = decrypt(a)
  print('加密', a)
  print('解密', b)

到此這篇關(guān)于python encrypt 實(shí)現(xiàn)AES加密的實(shí)例詳解的文章就介紹到這了,更多相關(guān)python encrypt 實(shí)現(xiàn)AES加密內(nèi)容請(qǐng)搜素腳本之家以前的文章或下面相關(guān)文章,希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論