ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

python3-AES-128-CBC算法填充模式用PKCS7Padding(PKCS#7)加密,解密!

2019-11-20 11:03:30  阅读:2286  来源: 互联网

标签:CBC AES PKCS Akey Avi key M16 data


算法用到3个参数:

1、用户密码 (明文密码)

2、传入一个16字节的key

3、传入一个16字节的初始偏移向量IV 

代码实现:

import base64
from Crypto.Cipher import AES
# 密钥(key), 密斯偏移量(iv) CBC模式加密
import hashlib

 

#偏移向量,假设加密VI ='hsdjlkasdlkasdlkas' 则:

Avi = bytes('hsdjlkasdlkasdlkas', encoding='utf-8')

#Key值   假设key值 key='jaslkjlkfjasldkj' 则:
Akey = bytes('jaslkjlkfjasldkj',encoding='utf-8') # key

 

#==================================================================

根据实际需求 来判断 是否需要用 传参转换的值 进行加密!

#M2_Avi = hashlib.md5(Avi).digest() # 返回摘要,作为二进制数据字符串值
#M2_Akey = hashlib.md5(Akey).digest()  #返回摘要,作为二进制数据字符串值

#M16_Avi = hashlib.md5(Avi).hexdigest() # 返回摘要,作为十六进制数据字符串值
#M16_Akey = hashlib.md5(Akey).hexdigest()  #返回摘要,作为十六进制数据字符串值

#==================================================================

#加密:

def AES_Encrypt(Avi,key, data):
  vi = Avi
  pad = lambda s: s + (16 - len(s)%16) * chr(16 - len(s)%16)
  data = pad(data)
  # 字符串补位
  cipher = AES.new(key, AES.MODE_CBC, vi)
  encryptedbytes = cipher.encrypt(data.encode('utf8'))
  # 加密后得到的是bytes类型的数据
  encodestrs = base64.b64encode(encryptedbytes)
  # 使用Base64进行编码,返回byte字符串
  enctext = encodestrs.decode('utf8')
  # 对byte字符串按utf-8进行解码
  return enctext

#解密

def AES_Decrypt(Avi,key, data):

  vi = Avi
  data = data.encode('utf8')
  encodebytes = base64.decodebytes(data)
  # 将加密数据转换位bytes类型数据
  cipher = AES.new(key, AES.MODE_CBC, vi)
  text_decrypted = cipher.decrypt(encodebytes)
  unpad = lambda s: s[0:-s[-1]]
  text_decrypted = unpad(text_decrypted)
  # 去补位
  text_decrypted = text_decrypted.decode('utf8')
  return text_decrypted

 

data ='123456' #明文密码

#加密:

AES_Encrypt(M16_Avi,M16_Akey,data) # 这里 偏移量(VI) key值(key)使用十六进制数据字符串值(M16_Avi , M16_Akey)

#解密:

enctext = AES_Encrypt(M16_Avi,M16_Akey,data) #加密密码

AES_Decrypt(M16_Avi,M16_Akey,enctext) # #解密 —— 传入 VI ,key, 加密密码(enctext ) 

 

(有错误请提示,有更好的方式请指教!)

 

标签:CBC,AES,PKCS,Akey,Avi,key,M16,data
来源: https://www.cnblogs.com/lzf2018pangpangxie/p/11896299.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有