0

0

Python 使用 YAML 配置的风险点

冷炫風刃

冷炫風刃

发布时间:2026-02-16 13:00:50

|

669人浏览过

|

来源于php中文网

原创

yaml 的 load() 函数默认不安全,会执行任意 python 对象构造;应始终使用 yaml.safe_load(),仅解析基础类型;必要时用 csafeloader 或 fullloader 并确保来源可信;避免超大文件,注意锚点与深拷贝风险。

python 使用 yaml 配置的风险点

YAML 的 load() 函数默认不安全

Python 的 PyYAML 库里,yaml.load() 会执行任意 Python 对象构造(比如 !python/object/apply),只要配置文件里写了恶意标签,就能触发代码执行。这不是“可能”,而是只要用了旧版默认调用方式,就等于在入口处开了个 eval() 后门。

实操建议:

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

  • 永远用 yaml.safe_load() 替代 yaml.load() —— 它只支持基础 YAML 类型(字符串、数字、列表、字典等),拒绝所有自定义标签和对象构造
  • 如果必须解析带标签的 YAML(比如 Kubernetes 配置里的 !!str),确认来源绝对可信,并显式传入 Loader=yaml.CSafeLoader(C 加速版)或 yaml.FullLoader(仅限已知可控场景)
  • 检查项目依赖:运行 pip show pyyaml,若版本 safe_load 仍是默认行为但文档不明显;5.1+ 才真正把 load() 标为弃用

类型自动转换导致数据“悄悄变样”

YAML 解析器会按规则把某些字符串转成布尔、时间、数字甚至 null,比如 yesTrue2023-01-01datetime.date 对象、012383(八进制)。这些不是 bug,是 YAML 规范本身的设计,但和 Python 开发者直觉冲突。

实操建议:

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

  • 所有需要保持原始字符串语义的字段(如 ID、密码、带前导零的编号),加单引号包裹:'0123''yes'
  • 避免用 YAML 表示“弱类型”配置,比如开关字段统一用 enabled: true 而不是 enabled: on,减少歧义
  • 如果配置项需强类型校验,别靠 YAML 自动转换,改用 pydanticdataclasses 做反序列化后验证

注释和锚点在运行时不可见

YAML 支持注释(#)和锚点(&anchor + *anchor),但 yaml.safe_load() 返回的是纯 Python 原生结构(dict/list),所有注释被丢弃,锚点也被展开成重复值 —— 你没法在运行时知道某段配置原本有没有注释,也无法追溯某个值是否来自锚点引用。

实操建议:

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

  • 别把业务逻辑依赖注释(例如用注释标记“此字段已废弃”),这类信息应写进字段名或额外元数据字段
  • 锚点适合简化编写,但会增加调试难度:两个看似独立的配置项实际指向同一内存对象,修改其中一个会影响另一个;如需深拷贝行为,加载后手动 copy.deepcopy()
  • 若需保留注释结构(如配置编辑工具),换用 ruamel.yaml 库,它提供 CommentedMap 等类型,但代价是更重、API 更复杂

大文件或嵌套过深时性能和栈溢出风险

PyYAML 默认使用递归解析,当 YAML 文件超过几千行,或嵌套层级超过 100 层(比如意外生成的深度缩进模板),容易触发 RecursionError 或显著拖慢加载速度。这在 CI/CD 加载大型 Helm values 文件或微服务配置时很常见。

实操建议:

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

  • yaml.CSafeLoader 替代 yaml.SafeLoader(纯 Python 实现),C 扩展版快 3–5 倍且递归控制更稳
  • 限制嵌套深度:加载前先用正则粗筛缩进层数,或设置 yaml.Loaderyaml.load(stream, Loader=MyLimitedLoader) 自定义限制
  • 超大配置(>1MB)考虑拆分:按模块分文件,用 Python 逻辑合并,而不是堆一个巨无霸 YAML

最麻烦的其实是组合风险——比如用了 safe_load 却没防住类型转换,又或者加了锚点却忘了深拷贝,问题要等运行一段时间才暴露。配置不是写完就完的事,它得经得起 reload、diff、merge 和多人协作的反复折腾。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

348

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

425

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

786

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

356

2025.07.23

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

244

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

746

2024.03.01

js 字符串转数组
js 字符串转数组

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

552

2023.08.03

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

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

216

2023.09.04

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

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

145

2026.02.13

热门下载

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

精品课程

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

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.6万人学习

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

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