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

php,python aes加密反解

1. python版本

import base64
from Crypto.Cipher import AES
from Crypto.Util.Padding import pad, unpadclass AESUtilCBC:def __init__(self, key, iv):self.key = key.encode('utf-8')self.iv = iv.encode('utf-8')self.pad_length = AES.block_sizedef encrypt(self, data):try:data = data.encode('utf-8')cipher = AES.new(self.key, AES.MODE_CBC, self.iv)padded_data = pad(data, self.pad_length, style='pkcs7')encrypted_data = cipher.encrypt(padded_data)encoded_data = base64.b64encode(encrypted_data).decode('utf-8')return encoded_dataexcept Exception as e:raise Exception(f"Encryption failed: {str(e)}")def decrypt(self, encrypted_data):try:encrypted_bytes = base64.b64decode(encrypted_data)cipher = AES.new(self.key, AES.MODE_CBC, self.iv)decrypted_data = cipher.decrypt(encrypted_bytes)unpadded_data = unpad(decrypted_data, self.pad_length, style='pkcs7')return unpadded_data.decode('utf-8')except Exception as e:raise Exception(f"Decryption failed: {str(e)}")# 示例使用 AESUtilCBC 类进行加密和解密
# 定义密钥和初始向量(IV)
key = 'Nhic0EAJqsIdMBfs'  # 16字节的密钥
iv = 'Nhic0EAJqsIdMBfs'   # 16字节的初始向量# 创建 AESUtilCBC 类的实例
aes_util = AESUtilCBC(key, iv)# 要加密的数据
data = '123456'# 调用加密方法
encrypted_data = aes_util.encrypt(data)
print(f"加密后的数据: {encrypted_data}")# 调用解密方法
decrypted_data = aes_util.decrypt(encrypted_data)
print(f"解密后的数据: {decrypted_data}")

执行以后是

加密后的数据: Qun8LbhlewyVvRQDzrNCIQ==
解密后的数据: 123456

2. php代码

<?phpuse Exception;class AESUtilCBC
{private $key = 'Nhic0EAJqsIdMBfs';private $iv = 'Nhic0EAJqsIdMBfs';private $algo = 'AES-128-CBC';private $options = OPENSSL_RAW_DATA;public function __construct($key = null, $iv = null, $algo = null, $options = null){if ($key) {$this->key = $key;}if ($iv) {$this->iv = $iv;}if ($algo) {$this->algo = $algo;}if ($options) {$this->options = $options;}}/*** 加密** @param $data* @return false|string*/public function encrypt($data){try {$encryptedData = openssl_encrypt($data, $this->algo, $this->key, $this->options, $this->iv);return base64_encode($encryptedData);} catch (Exception $e) {return false;}}/*** 解密** @param $encryptedData* @return false|string*/public function decrypt($encryptedData){try {$decodedData = base64_decode($encryptedData);return openssl_decrypt($decodedData, $this->algo, $this->key, $this->options, $this->iv);} catch (Exception $e) {return false;}}
}$encrypted_data = (new AESUtilCBC())->encrypt('123456');
print("加密后的数据: {$encrypted_data}<br>");$decrypted_data = (new AESUtilCBC())->decrypt($encrypted_data);
print("解密后的数据: {$decrypted_data}");

执行以后是

加密后的数据: Qun8LbhlewyVvRQDzrNCIQ==
解密后的数据: 123456

3. 其他

1. 在线测试
可以在一些在线网站来进行测试是否加密一致
例如  https://www.ssleye.com/ssltool/aes_cipher.html

在线网站加密

2. 128 256 php和python如何修改
php: $algo可以设置为 AES-128-CBC,AES-256-CBC
python:根据 key 的长度而变化,16位为128, 32位为256
3. iv长度
iv长度必须为16位,key和iv允许一致
4. 加密不一致
如果key的长度不足16或者32位,在php或python代码中进行补全空位,如果补全长度的字符不一致,则会导致加密的不一致
5. php 修改模式
修改 AES-128-CBC 的 CBC 为 ECB 等
http://www.lryc.cn/news/379341.html

相关文章:

  • 基于Java学生选课管理系统设计和实现(源码+LW+调试文档+讲解等)
  • 阅读笔记——《Large Language Model guided Protocol Fuzzing》
  • C#委托:事件驱动编程的基石
  • Git的下载安装及可视化工具小乌龟
  • 【面试实战】# 并发编程之线程池配置实战
  • Pytest 读取excel文件参数化应用
  • qt 一个可以拖拽的矩形
  • C# 启动exe 程序
  • Netty中的Reactor模型实现
  • dll丢失应该怎么解决,总结5种解决DLL丢失问题的方法
  • dial tcp 10.96.0.1:443: connect: no route to host
  • VScode创建ROS项目 ROS集成开发环境
  • nodejs从基础到实战学习笔记-nodejs简介
  • 2024年最新版------二进制安装部署Kubernetes(K8S)集群
  • 【mysql】关键词搜索实现
  • Python面试十问2
  • C# OpenCvSharp 图像处理函数-颜色通道-cvtColor
  • 总结之LangChain(三)——模型IO缓存
  • 判断一个Java服务是不是GateWay
  • 三次插值曲线--插值技术
  • python循环结构
  • 深入理解Netty的Pipeline机制:原理与实践详解
  • 直方图均衡化示例
  • 私域电商新纪元:消费增值模式的创新与成功实践
  • Java——IO流(一)-(6/8):字节流-FileInputStream 每次读取多个字节(示例演示)、一次读取完全部字节(方式一、方式二,注意事项)
  • 服务器SSH 免密码登录
  • Linux安装MySQL以及远程连接
  • SQL Server 数据库分页技术详解:选择最佳方法优化查询性能”。
  • electron录制-镜头缩放、移动
  • 红队内网攻防渗透:内网渗透之内网对抗:信息收集篇自动项目本机导出外部打点域内通讯PillagerBloodHound