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.mzph.cn/news/871663.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python:绘制一元三次函数的曲线

编写 test_x3_3x.py 如下 # -*- coding: utf-8 -*- """ 绘制函数 y x^33x4 在 -3<x<3 的曲线 """ import numpy as np from matplotlib import pyplot as plt# 用于正常显示中文标题&#xff0c;负号 plt.rcParams[font.sans-serif] […

Games101——光珊化——深度缓存——shading着色 1

深度缓存 如何解决远近的问题&#xff0c;能正确的覆盖 按照画作来说&#xff0c;先画出远处的物体&#xff0c;再画出近处的物体&#xff0c;近处会将其覆盖&#xff0c;这种算法叫做画家算法 但事实上&#xff0c;排序不仅要花更多的时间&#xff0c;而且排序并不容易&…

RIP路由协议概述

RIP【Routing Information Protocol】 RIP是为TCP/IP 环境中开发的第一个路由选择协议标准 RIP是一个【距离——矢量】路由选择协议 当路由器的更新周期为30s到来时&#xff0c;向邻居发送路由表 RIP以跳数作为唯一度量值 RIP工作原理 RIP路由协议向邻居发送整个路由表信息RI…

农场资源的获取

一、网站 资源 二、搜索土壤资源 1、找到类别&#xff0c;点击Browse Texture 2、搜索、选择 3、搜索Brown Mud Dry 4、搜索Brown Mud 三、

深入探索Laravel框架中的Blade模板引擎

Laravel是PHP界广受欢迎的一个现代Web应用框架&#xff0c;以其优雅、简洁的代码风格和强大的功能而闻名。在Laravel中&#xff0c;模板引擎是一个不可或缺的组件&#xff0c;它负责将数据和视图模板结合起来&#xff0c;生成最终的HTML内容。Laravel默认使用的模板引擎是Blade…

[web]-图片上传、文件包含-图片上传

题目内容提示&#xff1a;上传图片试试吧&#xff0c;注意统一时区问题 打开页面如图&#xff0c;源码没有过滤&#xff0c;随便输入&#xff0c;进入上传目录 根据链接可以看到是文件包含&#xff0c;可以利用编码读取源码&#xff0c;这里只列出有用页面的编码&#xff08;?…

CSS盒模型的定义以及标准盒模型与IE盒模型的区别

CSS盒模型解释 CSS盒模型是CSS中一个非常重要的概念&#xff0c;它定义了一个HTML元素在页面中所占据的空间。盒模型决定了元素的尺寸、边距和边框的大小&#xff0c;以及元素的内部内容的布局。它由四个部分组成&#xff1a;内容区域&#xff08;content&#xff09;、内边距…

【Hive SQL 每日一题】在线峰值人数计算

文章目录 测试数据需求说明需求实现 测试数据 -- 创建 user_activity 表 DROP TABLE IF EXISTS user_activity ; CREATE TABLE user_activity (user_id STRING,activity_start TIMESTAMP,activity_end TIMESTAMP );-- 插入数据 INSERT INTO user_activity VALUES (user1, 2024…

大模型-Bert+PET实战

PET&#xff08;Pattern-Exploiting Training&#xff09; 背景&#xff1a;预训练语言模型&#xff08;比如BERT&#xff09;知识全面&#xff0c;但是没有针对下游任务做针对训练&#xff0c;所以效果一般&#xff0c;所以需要根据任务做微调。 核心思想&#xff1a;根据先…

【问题解决】Could not find a package configuration file provided by “autoware_msgs“

问题描述 通过catkin_make命令编译时&#xff0c;产生问题如下&#xff1a; Base path: /home/defu/PncProject/frenet_planner_ws Source space: /home/defu/PncProject/frenet_planner_ws/src Build space: /home/defu/PncProject/frenet_planner_ws/build Devel space: /…

银河麒麟高级服务器操作系统 V10 SP3 2403

系统简介 银河麒麟高级服务器操作系统V10是一款为企业级关键业务设计的新一代自主服务器操作系统&#xff0c;它满足虚拟化、云计算、大数据等时代需求&#xff0c;具备高可靠性、安全性、性能和扩展性。该系统基于CMMI5级标准开发&#xff0c;支持多种国产处理器平台&#xf…

PTA 7-15 希尔排序

本题目要求读入N个整数&#xff0c;采用希尔排序法进行排序&#xff0c;采用增量序列{5&#xff0c;3&#xff0c;1}&#xff0c;输出完成增量5和增量3后的5子排序和3子排序结果。 输入格式: 输入不超过100的正整数N和N个整数&#xff08;空格分隔&#xff09;。 输出格式: …

UDP网络通信(发送端+接收端)实例 —— Python

简介 在网络通信编程中&#xff0c;用的最多的就是UDP和TCP通信了&#xff0c;原理这里就不分析了&#xff0c;网上介绍也很多&#xff0c;这里简单列举一下各自的优缺点和使用场景 通信方式优点缺点适用场景UDP及时性好&#xff0c;快速视网络情况&#xff0c;存在丢包 与嵌入…

重学PyTorch,粗略笔记(一)

很久之前学PyTorch记的笔记&#xff0c;顺手整理一下 安装 Start Locally | PyTorch pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu118tensors张量 标量是零维张量&#xff0c;向量是一维张量&#xff0c;矩阵是二维张量&am…

【密码学】分组密码的设计原则

分组密码设计的目标是在密钥控制下&#xff0c;从一个巨大的置换集合中高效地选取一个置换&#xff0c;用于加密给定的明文块。 一、混淆原则 混淆原则是密码学中一个至关重要的概念&#xff0c;由克劳德香农提出。混淆原则就是将密文、明文、密钥三者之间的统计关系和代数关系…

后端实现图片上传本地,可采用url查看图片

前言 本文将实现在数据库中存储图片url&#xff0c;url可以在浏览器中访问查看。 整体思路为&#xff1a; 上传图片到本地指定地址为图片分配url保存至数据库根据分配url&#xff0c;进行物理地址映射到本地指定地址 具体实现 controller层&#xff1a; 上传图片到本地指定…

【JavaEE】网络编程——TCP

&#x1f921;&#x1f921;&#x1f921;个人主页&#x1f921;&#x1f921;&#x1f921; &#x1f921;&#x1f921;&#x1f921;JavaEE专栏&#x1f921;&#x1f921;&#x1f921; 文章目录 前言1.网络编程套接字1.1流式套接字(TCP)1.1.1特点1.1.2编码1.1.2.1ServerSo…

玩转springboot之xxxRunner接口使用

Runner使用 如果需要在SpringApplication启动后执行一些逻辑&#xff0c;可以使用ApplicationRunner或CommandLineRunner接口&#xff0c;这两个接口都是只有一个run方法 public interface ApplicationRunner {void run(ApplicationArguments args) throws Exception;}public…

华为USG6000V防火墙v1

目录 一、实验拓扑图 二、要求 三、IP地址规划 四、实验配置 1&#x1f923;防火墙FW1web服务配置 2.网络配置 要求1&#xff1a;DMZ区内的服务器&#xff0c;办公区仅能在办公时间内(9:00-18:00)可以访问&#xff0c;生产区的设备全天可以访问 要求2&#xff1a;生产区不…

电影《头脑特工队2》观后感

上周看了电影《头脑特工队2》&#xff0c;整体是非常不错的&#xff0c;一个大脑中&#xff0c;想象的世界。 &#xff08;1&#xff09;人格-多元政体理论 记得前几年是看过《头脑特工队1》的&#xff0c;当时电影是非常出名的&#xff0c;当时有很多研究理论&#xff0c;都…