当前位置: 首页 > news >正文

python实现openssl的EVP_BytesToKey及AES_256_CBC加解密算法

python实现openssl
EVP_BytesToKey(EVP_aes_256_cbc(), EVP_md5(), NULL, pass, passlen, 1, key, iv);
并实现AES 256 CBC加解密.

# encoding:utf-8import base64
from Crypto.Cipher import AES
from Crypto import Random
from hashlib import md5def EVP_BytesToKey(password, salt, key_len, iv_len):"""实现opensslEVP_BytesToKey(EVP_aes_256_cbc(), EVP_md5(), NULL, pass, passlen, 1, key, iv);"""pass_salt = (password + salt).encode(encoding='utf-8') #传给hashlib.md5前要先转成bytesdtot = md5(pass_salt).digest() # 返回bytes,不要转成十六进制字符串d = [ dtot ]while len(dtot) != (key_len + iv_len):d.append(md5(d[-1] + pass_salt).digest()) # 在一维列表中,下标为-1表示该元素为列表的最后一项dtot += d[-1]return dtot[:key_len], dtot[key_len:key_len+iv_len]def encryt(string, key, iv):"""加密文本:param string: 待加密文本:param key: 密钥:param iv: 偏移量/初始向量:return: 密文"""cipher = AES.new(key, AES.MODE_CBC, iv)x = AES.block_size - (len(string) % AES.block_size)# 长度不整除16时,需要进行补全, 比如少了3个,就填充3个3if x != 0:string = string + chr(x)*xmsg = cipher.encrypt(string.encode('utf-8'))return msgdef decrypt(en_str, key, iv):"""解密文本:param en_str: 待解密文本:param key: 密钥:param iv: 偏移量/初始向量:return: 解密后的文本"""cipher = AES.new(key, AES.MODE_CBC, iv)msg = cipher.decrypt(en_str)padding_len = msg[len(msg)-1]return msg[0:-padding_len]if __name__ == '__main__':with open('res.json', 'r') as fp:content = fp.readlines() #listtext_16str = ''.join(content) # list to strtext_byte = bytes.fromhex(text_16str) #get bytespassword = "%^%xxxxxx"key, iv = EVP_BytesToKey(password, '', 32, 16)#out = encryt('world', key, iv)print(out.hex())out = decrypt(text_byte, key, iv)print(out.decode('utf-8'))

作者:帅得不敢出门 csdn原创谢绝转载收录

http://www.lryc.cn/news/400077.html

相关文章:

  • 基于SpringBoot+VueJS+微信小程序技术的图书森林共享小程序设计与实现
  • 【css】image 使用 transform:scale 放大后显示不全的问题
  • 损失函数简介
  • 2023睿抗CAIP-编程技能赛-本科组省赛(c++)
  • 现在国内的ddos攻击趋势怎么样?想了解现在ddos的情况该去哪看?
  • 微服务到底是个什么东东?
  • C++笔试强训5
  • 初学51单片机之UART串口通信
  • 数据结构——查找(线性表的查找与树表的查找)
  • MySQL入门学习-深入索引.组合索引
  • RABBITMQ的本地测试证书生成脚本
  • 记录些Redis题集(4)
  • JVM:垃圾回收器
  • Golang | Leetcode Golang题解之第228题汇总区间
  • 单目3D和bev综述
  • 每日Attention学习11——Lightweight Dilated Bottleneck
  • EM32DX-E4 IO 扩展模块
  • 【数据结构与算法】选择排序篇----详解直接插入排序和哈希排序【图文讲解】
  • SpringBoot实战:多表联查
  • 解决mysql,Navicat for MySQL,IntelliJ IDEA之间中文乱码
  • 虚拟环境操作
  • 企业网三层架构
  • node.js的安装及学习(node/nvm/npm的区别)
  • 性能优化篇:用WebSocket替代传统的http轮循
  • virtualbox的ubuntu默认ipv4地址为10.0.2.15的修改以及xshell和xftp的连接
  • Codeforces Round 957 (Div. 3)(A~D题)
  • fedora 40 安装拼音输入法
  • Chromium CI/CD 之Jenkins实用指南2024-如何创建新节点(三)
  • Git代码管理工具 — 3 Git基本操作指令详解
  • Linux——多线程(五)