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: 10

YAML 解析器(包括 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令牌生成与请求验证【教程】