0

0

Python 热修复的代码注入风险

舞夢輝影

舞夢輝影

发布时间:2026-02-21 15:40:36

|

734人浏览过

|

来源于php中文网

原创

热修复禁用exec/eval因存在任意代码执行风险;应使用types.functiontype替换函数对象,确保逻辑来自可信模块,避免远程字符串注入。

python 热修复的代码注入风险

Python 热修复时 execeval 为什么不能直接用

热修复本质是运行时动态加载新逻辑,但用 execeval 执行远程/外部传入的字符串代码,等于主动打开任意代码执行后门。哪怕只修一行,只要输入可控,攻击者就能调 os.system、删文件、窃取环境变量。

常见错误现象:SyntaxError 反而是好事;更危险的是静默执行了恶意逻辑,比如修复函数里悄悄加了 requests.post(...) 回传内存数据。

  • 使用场景:线上紧急 patch 函数行为,比如修复某个计算逻辑 bug
  • 参数差异:传字符串 vs 传已编译的 codeobject —— 后者仍不安全,只要来源不可信
  • 性能影响:小,但安全代价远高于这点开销
  • 兼容性无问题,但所有 Python 版本都一样危险

真正可用的热修复方式:用 types.FunctionType 替换函数对象

核心思路是——只替换函数体,不执行任意字符串。把修复逻辑写在本地模块里,编译成字节码,再用 types.FunctionType 构造新函数并赋值到原位置。这样控制权始终在可信代码路径内。

实操建议:

立即学习Python免费学习笔记(深入)”;

ecshop
ecshop

本版本全面兼容php5.6+,并且修复了许多官方程序的低级代码bug。在apache 2.4.17+php5.6.15环境下测试通过,人格保证无毒无木马,仅仅是一名ecshop热爱者心血来潮之作。ecshop编译更新日志:1、加入最新官方补丁。2、修改数据库连接底层为mysqli, 现在完美无缺了。3、再次对所有代码进行细节修复。4、adminers更新至1.1.2, 在线管理数据库的神器。5、测

下载
  • 修复代码必须提前写在项目内(如 hotfixes/fix_calc.py),不能从网络或配置中心拉字符串
  • inspect.getsource 提取函数源码 → compile 得到 codeobjecttypes.FunctionType 构造,比手写 exec 多两行,但安全边界清晰
  • 注意闭包变量:原函数引用的自由变量(nonlocal 或外层作用域变量)不会自动继承,得手动传进新函数的 globals 或重构为参数
  • 类方法热修复要额外处理 __func__ 和绑定逻辑,不如直接改实例的 __dict__

示例:new_func = types.FunctionType(compile(src, '', 'exec').co_consts[0], globals()) —— 注意 co_consts[0] 是假设你 compile 的是单个函数定义,实际需按 AST 解析定位

热修复后函数没生效?检查这三个地方

不是代码写错,而是 Python 的名字绑定机制让人误以为“改了就生效”。真实情况是:引用关系没断,旧函数还在被调用。

  • 模块级函数:确认你替换的是被调用方看到的那个名字,比如 from module import func 后再 module.func = new_func 不生效,因为导入时已绑定到本地符号表
  • 类方法:直接改 Class.method = new_func 只影响新实例;已有实例的方法绑定已固化,得遍历 instance.__dict__ 或重设 instance.__class__.method
  • 装饰器干扰:如果原函数被 @lru_cache@property 包裹,热修复后缓存未清、描述符逻辑未更新,表现仍是旧行为

别忽略 importlib.reload 的副作用

有人图省事直接 importlib.reload(module),觉得“重载整个模块”最彻底。但它会创建全新模块对象,而老模块里的对象(如全局 dict、单例类实例、线程局部存储)不会自动迁移,极易引发状态不一致。

典型症状:AttributeError 找不到刚 reload 过的属性,或者两个模块版本的类实例互相不认(isinstance(obj, NewClass) 返回 False)。

  • reload 前必须确保:无长期持有老模块对象的引用(比如注册在 atexit 或信号 handler 里的函数)
  • reload 后必须手动同步状态:比如把老模块的 CACHE_DICT 内容 copy 到新模块对应位置
  • 某些 C 扩展模块(如 numpycv2)根本不能 reload,会直接 segfault

复杂点在于:热修复从来不只是“换一段逻辑”,而是“在不中断服务的前提下,让新旧状态平稳交接”。这个交接过程,比注入代码本身更难把控。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

595

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

217

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1555

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

641

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

986

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

939

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

186

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

89

2025.08.07

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

796

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.4万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号