开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 340|回复: 14
收起左侧

[已解决] 这段py代码怎么转换到易语言

 关闭 [复制链接]
结帖率:100% (1/1)
发表于 2025-4-22 13:58:04 | 显示全部楼层 |阅读模式   广东省佛山市
100精币
这段py代码怎么转换到易语言,求好心人告知
  
import base64
import urllib.parse
from Crypto.Cipher import AES
from Crypto.Util.Padding import unpad

def decrypt (url, text):
"""
使用 AES CBC 模式解密数据

:param url: 用于生成密钥和 IV 的字符串,一般是接口地址
:param text: 加密后的密文
:return: 解密后的明文
"""
if not isinstance (url, str):
return None

# 内部函数:生成 base64 编码并重复三次
def generate_key_iv (s):
# URI 编码后 base64 编码
encoded = base64.b64encode (urllib.parse.quote (s).encode ()).decode ()
return (encoded * 3)

# 生成密钥和初始向量
str_repeated = generate_key_iv (url)

# 从重复后的字符串中截取 key 和 iv
org_key = str_repeated[:16]     # 前 16 字符作为密钥
org_iv = str_repeated[12:28]    # 第 12~28 字符作为初始向量(IV)

# 解密
try:
# 将密文从 base64 解码
cipher_text = base64.b64decode (text)

# 创建解密器
cipher = AES.new (
key=org_key.encode ( ' utf-8'),
mode=AES.MODE_CBC,
iv=org_iv.encode ( ' utf-8')
)

# 解密并去除填充
decrypted = unpad (cipher.decrypt (cipher_text), AES.block_size)

# 转换为字符串
return decrypted.decode ( ' utf-8')

except Exception as e:
print (f"Decryption error: {e}")
return None

# 示例调用
if __name__ == "__main__":
url = ' /api/rank/author/fans/increment'
data = ' pNgodwr8Bn+1lFcoCpk5NVt/gN+gQwnu8gW0sZiShqJnc2VNtCkVUn/MOWLKWOFG+AXPxIkUlwx/RyCNVMF10JkBHELqU2sFdbLV0uMZ/kV/XSDjX7qo6xfoMEt530H+3YZFt0Nx19zv4jV4EujYCjKtI98bcVpdwM2ZX9d9b5XNChZNYIFYDErUd+aM2LpXOtkZd78BpIAF+M5syOlAHyGrdavUnvKUUIG5w5U44dNLhaPqTPrECZpOtMCIi8XP8Mxv8K1jhSE6Q6efMUCC2cv2QA0xEL3QDUB2jK2O'
print (decrypt (url, data))

最佳答案

查看完整内容

代码,很简单,问题出在你的原始密文。本身是错的。 py里运行,就已经报错了Data must be padded to 16 byte boundary in CBC mode 你用这个密文在易语言里运行,肯定,也是错的 话说,这个问题,我咋感觉有点眼熟呢

回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳
结帖率:93% (253/272)
发表于 2025-4-22 13:58:05 | 显示全部楼层   广西壮族自治区崇左市
代码,很简单,问题出在你的原始密文。本身是错的。
py里运行,就已经报错了Data must be padded to 16 byte boundary in CBC mode
你用这个密文在易语言里运行,肯定,也是错的

话说,这个问题,我咋感觉有点眼熟呢

aes加解密.e

183.44 KB, 下载次数: 2

回复

使用道具 举报

结帖率:100% (2/2)

签到天数: 9 天

发表于 2025-4-22 14:00:29 | 显示全部楼层   广东省东莞市
直接调用e2ee 的加解密对象命令
回复

使用道具 举报

结帖率:100% (1/1)

签到天数: 6 天

 楼主| 发表于 2025-4-22 14:03:58 | 显示全部楼层   广东省佛山市
菜鸟路过 发表于 2025-4-22 14:00
直接调用e2ee 的加解密对象命令

大哥能给个例子吗
回复

使用道具 举报

结帖率:88% (80/91)

签到天数: 8 天

发表于 2025-4-22 14:08:30 | 显示全部楼层   江苏省苏州市
这个需要库  实现  这个py并非源码
而是调用库的方法
回复

使用道具 举报

结帖率:50% (2/4)

签到天数: 10 天

发表于 2025-4-22 14:13:00 | 显示全部楼层   福建省厦门市
回复

使用道具 举报

结帖率:88% (7/8)

签到天数: 4 天

发表于 2025-4-22 14:17:08 | 显示全部楼层   上海市上海市
可以问 豆包
回复

使用道具 举报

结帖率:100% (1/1)

签到天数: 6 天

 楼主| 发表于 2025-4-22 14:31:20 | 显示全部楼层   广东省佛山市
lao3 发表于 2025-4-22 14:13
我记得~

https://bbs.125.la/forum.php?mod=viewthread&tid=14852344&extra=

就是这个~我去验证了一下,发现返回空
回复

使用道具 举报

结帖率:100% (22/22)

签到天数: 10 天

发表于 2025-4-22 14:32:20 | 显示全部楼层   福建省泉州市
100精币不少了,如果是RMB我愿意帮写
回复

使用道具 举报

结帖率:50% (2/4)

签到天数: 10 天

发表于 2025-4-22 14:49:19 | 显示全部楼层   福建省厦门市
流年浮生 发表于 2025-4-22 14:31
就是这个~我去验证了一下,发现返回空

你的python代码也解不了啊,报错了~

检查下密文密钥是否匹配吧~
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表