YAMLMapper 解析带点号(.)的嵌套键名时的正确用法
发布时间 - 2025-12-29 00:00:00 点击率:次jackson 的 yamlmapper 默认不将点号(.)视为嵌套路径分隔符;它严格遵循 yaml 规范,将 `formatting.template` 视为一个完整键名而非嵌套结构,因此需配合正确的 json pointer 路径(如 `/formatting.template`)才能准确定位。
在使用 Jackson 的 YAMLMapper 解析 YAML 配置时,一个常见误区是认为 YAML 中的点号(.)天然表示嵌套层级(如 formatting.template.fields 等价于 formatting: template: fields:)。但YAML 本身并不将 . 当作语法分隔符——它只是一个普通字符。只有 Spring Boot 等框架在内部将 YAML 转为 Properties 结构时,才会把未转义的点号解释为层级分隔符。
因此,当你写如下 YAML:
formatting.template:
fields:
- name: birthdate
type: java.lang.String
subType: java.util.Date
lenght: 10YAML 解析器(包括 YAMLMapper)会将其解析为一个 单层映射,其 key 是字符串 "formatting.template",value 是一个包含 fields 的对象。此时,若你仍使用 JSON Pointer /formatting/template(意图为“进入 formatting 对象 → 进入 template 对象”),就会因路径不匹配而触发 MismatchedInputException 或 No content to map due to end-of-input —— 因为实际根对象中根本不存在名为 formatting 的字段。
✅ 正确做法是:保持 YAML 键名原样,并使用与之严格匹配的 JSON Pointer:
return mapper.readerFor(FormattingConfigurationProperties.class)
.at("/formatting.template") // ← 关键:路径必须含点号,且加引号(JSON Pointer 规范)
.readValue(inputStream);⚠️ 注意事项:
- JSON Pointer 中若路径含特殊字符(如 ., /, ~),需按 RFC 6901 规范进行转义:. → ~1,~ → ~0。但 YAMLMapper 的 at() 方法对简单点号通常可直接支持(无需转义为 ~1),推荐优先尝试 /formatting.template;若失败,再试 /formatting~1template。
- @ConfigurationProperties + Spring Boot 场景下,.yml 文件由 Spring 自动转换为扁平化 PropertySource,此时 formatting.template.fields[0].name 可直接绑定,无需手动调用 YAMLMapper。本文讨论的是纯 Jackson YAMLMapper 手动解析场景。
- 若希望保持语义清晰且避免歧义,更推荐采
用标准嵌套格式(即换行缩进):
formatting:
template:
fields:
- name: birthdate
type: java.lang.String
subType: java.util.Date
lenght: 10对应代码不变(仍用 /formatting/template),语义明确、兼容性强、不易出错。
总结:YAML 中的点号不是语法符号,而是键名的一部分;Jackson 不做自动“点号拆分”,务必让 JSON Pointer 路径与 YAML 实际结构完全一致。理解这一差异,即可彻底规避 MismatchedInputException。
# java
# js
# json
# app
# stream
# spring
# spring boot
# 字符串
# pointer
# map
# 对象
# input
# 是一个
# 分隔符
# 可直接
# 键名
# 不将
# 的是
# 这一
# 就会
# 不存在
# 不做
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
ChatGPT 4.0官网入口地址 ChatGPT在线体验官网
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
Laravel Blade组件怎么用_Laravel可复用视图组件的创建与使用
如何为不同团队 ID 动态生成多个独立按钮
Laravel如何处理异常和错误?(Handler示例)
Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程
如何利用DOS批处理实现定时关机操作详解
高端建站三要素:定制模板、企业官网与响应式设计优化
JavaScript常见的五种数组去重的方式
开心动漫网站制作软件下载,十分开心动画为何停播?
JS中对数组元素进行增删改移的方法总结
Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】
如何批量查询域名的建站时间记录?
如何快速建站并高效导出源代码?
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践
悟空识字如何进行跟读录音_悟空识字开启麦克风权限与录音
如何基于PHP生成高效IDC网络公司建站源码?
C++时间戳转换成日期时间的步骤和示例代码
香港服务器网站生成指南:免费资源整合与高速稳定配置方案
如何安全更换建站之星模板并保留数据?
如何解决hover在ie6中的兼容性问题
Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】
如何生成腾讯云建站专用兑换码?
用v-html解决Vue.js渲染中html标签不被解析的问题
教学论文网站制作软件有哪些,写论文用什么软件
?
Laravel如何实现事件和监听器?(Event & Listener实战)
Laravel怎么自定义错误页面_Laravel修改404和500页面模板
深圳网站制作培训,深圳哪些招聘网站比较好?
laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法
装修招标网站设计制作流程,装修招标流程?
微信小程序 input输入框控件详解及实例(多种示例)
Laravel如何实现数据库事务?(DB Facade示例)
Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧
iOS验证手机号的正则表达式
如何撰写建站申请书?关键要点有哪些?
Laravel如何生成URL和重定向?(路由助手函数)
html5怎么画眼睛_HT5用Canvas或SVG画眼球瞳孔加JS控制动态【绘制】
通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】
手机网站制作与建设方案,手机网站如何建设?
Laravel中DTO是什么概念_在Laravel项目中使用数据传输对象(DTO)
Laravel怎么上传文件_Laravel图片上传及存储配置
Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出
Win11搜索不到蓝牙耳机怎么办 Win11蓝牙驱动更新修复【详解】
Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】
Laravel如何从数据库删除数据_Laravel destroy和delete方法区别
Python高阶函数应用_函数作为参数说明【指导】
Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】


用标准嵌套格式(即换行缩进):