使用 JSON Schema 校验 oneOf 时避免不必要的枚举错误

使用 json schema 校验 oneof 时避免不必要的枚举错误

本文介绍了在使用 JSON Schema 的 oneOf 关键字进行数据校验时,如何理解和处理可能出现的“Value is not defined in enum”错误。通过分析示例,解释了这种错误产生的原因,并强调了 JSON Schema 校验器正确报告错误的重要性。

在使用 JSON Schema 验证 JSON 数据时,oneOf 关键字允许数据满足多个子模式中的一个。然而,当数据不符合任何一个子模式时,校验器可能会报告多个错误,其中一种常见的错误是 “Value is not defined in enum”。 理解这种错误的含义以及如何处理它对于有效地使用 JSON Schema 至关重要。

理解 oneOf 和枚举校验

oneOf 关键字指定数据必须根据给定的多个 schema 中的一个进行验证。每个 schema 都可以包含各种验证规则,包括 enum 关键字,用于限制属性的值只能是预定义集合中的一个。

例如,以下 JSON Schema 使用 oneOf 来定义两种可能的结构,具体取决于 eventName 的值:

{  "$schema": "https://json-schema.org/draft/2019-09/schema",  "type": "object",  "properties": {    "eventName": {      "type": "string",      "enum": ["Test10", "Test12", "Test1", "Test2", "Test3"]    },    "eventPayload": {      "type": "object",      "properties": {        "totalAmount": {          "type": "number"        }      }    }  },  "oneOf": [    {      "properties": {        "eventName": {          "enum": ["Test10", "Test12"]        },        "eventPayload": {          "properties": {            "totalAmount": {              "exclusiveMinimum": 0            }          }        }      }    },    {      "properties": {        "eventName": {          "enum": ["Test1", "Test2", "Test3"]        },        "eventPayload": {          "properties": {            "totalAmount": {              "exclusiveMaximum": 0            }          }        }      }    }  ]}

在此示例中,如果 eventName 是 “Test10” 或 “Test12″,则 totalAmount 必须大于 0。如果 eventName 是 “Test1″、”Test2” 或 “Test3″,则 totalAmount 必须小于 0。

错误消息的含义

当使用上述 schema 验证以下 JSON 数据时:

{  "eventName": "Test12",  "eventPayload": {    "totalAmount": -5  }}

校验器会报告以下错误:

Message:Value "Test12" is not defined in enum.Schema path:#/oneOf/1/properties/eventName/enumMessage:Integer -5 is less than minimum value of 0.Schema path:#/oneOf/0/properties/eventPayload/properties/totalAmount/minimum

第一个错误 “Value “Test12″ is not defined in enum.” 指出 eventName 的值 “Test12” 不在第二个 oneOf 子模式的 enum 列表中。第二个错误 “Integer -5 is less than minimum value of 0.” 指出 totalAmount 的值 -5 不满足第一个 oneOf 子模式中 exclusiveMinimum 的要求。

为什么会报告枚举错误?

重要的是要理解,校验器报告枚举错误是正确的行为。 oneOf 的目的是验证数据是否符合 至少一个 子模式。 如果数据不符合任何子模式,则校验失败,并且报告所有不符合的错误是有意义的。

v0.dev v0.dev

Vercel推出的AI生成式UI工具,通过文本描述生成UI组件代码

v0.dev 261 查看详情 v0.dev

在本例中,数据不符合第一个子模式,因为 totalAmount 小于 0。数据也不符合第二个子模式,因为 eventName 不是 “Test1″、”Test2” 或 “Test3″。 因此,校验器正确地报告了这两个错误。

如何处理枚举错误

虽然枚举错误是有效的,但在某些情况下,您可能希望以不同的方式处理它们。例如,您可能只想看到导致校验失败的 最相关的 错误。

不幸的是,JSON Schema 本身没有提供一种内置的方式来过滤或抑制特定的错误消息。 然而,您可以考虑以下方法:

修改 Schema: 如果可能,重新设计 schema 以避免不必要的错误。例如,可以合并 oneOf 中的子模式,或者使用 if/then/else 结构来更精确地定义验证规则。

后处理错误: 在代码中,您可以捕获校验器返回的错误列表,并根据您的需要进行过滤或排序。您可以根据 schema 路径或错误消息的内容来识别和删除不需要的错误。

使用自定义校验器: 您可以编写自己的 JSON Schema 校验器,并自定义其行为以满足您的特定需求。这需要更多的工作,但提供了最大的灵活性。

总结

当使用 JSON Schema 的 oneOf 关键字时,”Value is not defined in enum” 错误通常是校验器正确报告数据不符合某个子模式的结果。 虽然不能直接抑制这些错误,但可以通过修改 schema、后处理错误或使用自定义校验器来管理它们。 理解这些错误的原因和处理方法可以帮助您更有效地使用 JSON Schema 进行数据验证。

以上就是使用 JSON Schema 校验 oneOf 时避免不必要的枚举错误的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/746211.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月25日 17:45:10
下一篇 2025年11月25日 17:50:46

相关推荐

  • macOS下PHP开发:XAMPP和MAMP哪个更适合你?

    macOS系统下的PHP集成开发环境推荐 习惯使用PHP Study的开发者,在切换到macOS系统后,可能会面临寻找合适的PHP集成开发环境的问题。macOS系统本身提供了强大的软件包管理和环境配置机制,因此搭建PHP开发环境的方式有很多种。本文将介绍几个优秀的替代方案,它们类似于Windows下…

    2025年12月11日
    000
  • Laradock启动php-worker容器失败:如何解决docker-compose up -d php-worker命令报错?

    laradock启动php-worker容器失败:排查docker-compose up -d php-worker命令报错 许多Laradock用户在启动php-worker容器时,执行docker-compose up -d php-worker命令失败。本文将分析此问题,并提供解决方案。 问题…

    2025年12月11日
    000
  • ThinkPHP后台密码频改,审计结果未发现漏洞,该如何排查?

    ThinkPHP后台密码频繁修改,安全审计却未发现漏洞?如何排查? 许多开发者都面临着后台密码被频繁篡改的难题。本文针对使用ThinkPHP(TP)框架的开发者,在安全审计未发现明显漏洞的情况下,密码仍被频繁修改的情况,提供排查思路。 安全审计工具通常只能检测已知的漏洞,而攻击者可能利用未知漏洞(0…

    2025年12月11日
    000
  • Swiper轮播图鼠标悬停停止报错:如何解决swiper is not defined?

    Swiper轮播图鼠标悬停暂停功能实现及“swiper is not defined”错误排查 在Swiper轮播图中,实现鼠标悬停暂停自动播放,离开后继续播放,是一个常见的需求。本文将针对Swiper 3.4.2版本,分析一个常见的“swiper is not defined”错误,并提供解决方案…

    2025年12月11日
    000
  • Swiper自动轮播鼠标悬停停止报错:如何解决“swiper is not defined”问题?

    Swiper轮播图鼠标悬停暂停及继续播放功能实现及“swiper is not defined”错误解决方法 许多开发者在使用Swiper插件实现鼠标悬停暂停自动轮播功能时,可能会遇到swiper is not defined错误。本文将详细分析此问题并提供解决方案。 问题描述: 在Swiper 3…

    2025年12月11日
    000
  • Java和PHP AES加密如何实现数据互通?

    Java和PHP AES加密实现数据互通 本文阐述如何在Java和PHP环境下,确保AES加密数据能够相互解密。Java端采用AES/CBC/PKCS5Padding模式,密钥长度为128位,并使用SHA1PRNG处理密钥。我们将重点讲解如何利用PHP的OpenSSL库,实现与Java端兼容的AES…

    2025年12月11日
    000
  • Java和PHP如何实现AES加解密互通?

    Java与PHP AES加解密互通详解 本文阐述Java和PHP如何利用AES算法实现数据加解密互通。Java端采用AES/CBC/PKCS5Padding模式,密钥长度128位,并使用SHA1PRNG处理密钥。我们将演示PHP端如何借助OpenSSL库实现与Java端兼容的加解密功能。 Java代…

    2025年12月11日
    000
  • Laravel中如何提升Model自定义方法的代码可读性和IDE识别效率?

    优化Laravel Model自定义方法,提升代码可读性和IDE识别 在Laravel项目开发中,自定义Model方法时,常常遇到IDE无法识别的问题,导致代码跳转和自动提示失效,降低开发效率。 例如,News::query() 后链式调用的自定义方法可能无法获得IDE的自动补全功能。本文介绍两种解…

    2025年12月11日
    000
  • ThinkPHP数据集对象为什么可以像数组一样访问?

    ThinkPHP数据集对象的数组访问特性详解 在ThinkPHP框架中,您会发现数据集对象支持像数组一样使用方括号[]访问键值对。这是因为ThinkPHP巧妙地利用了PHP的ArrayAccess接口。 ThinkPHP的模型类(Model)实现了ArrayAccess接口,而数据集对象是模型对象的…

    2025年12月11日
    000
  • 如何将PPT转换为HTML5格式并保留视频和动画?

    ppt转html5,保留视频和动画的解决方法 问题:如何将ppt文档转换为html5格式,并保留其内部的视频和动画效果? 答案: 使用ppt导出为html 打开ppt文档。点击“文件”菜单。选择“导出”。在“导出为”选项中选择“html”。 注意:该方法仅适用于简单的ppt文档,无法保留复杂的动画和…

    好文分享 2025年12月11日
    000
  • Excel超链接转PDF后丢失了?怎么办?

    Excel转PDF后超链接丢失的解决方法 许多用户在将Excel文件转换为PDF格式后,发现其中的超链接信息丢失了。这篇文章将探讨这个问题的原因以及可能的解决方法。 问题描述: 在将包含超链接的Excel文件转换为PDF文件时,PDF文件中超链接信息常常无法保留。这给用户带来了不便,特别是当需要在P…

    2025年12月11日
    000
  • 使用JetBrains教育许可开发商业项目:风险有多大?

    JetBrains教育许可与商业项目开发:风险分析 部分企业利用JetBrains开发工具(例如PhpStorm、IDEA)的教育许可开发商业项目。然而,此举存在潜在法律风险,务必谨慎。 JetBrains教育许可条款明确禁止将使用该许可开发的代码用于商业盈利活动。若企业以此类代码获利,则构成违约。…

    2025年12月11日
    000
  • 教育版许可开发商业项目:风险有多大?如何规避?

    JetBrains教育版许可用于商业项目:风险评估与解决方案 部分企业利用JetBrains教育版许可开发商业项目,此举存在显著风险。本文将分析其潜在影响,并提供相应的规避策略。 教育版许可的限制与违规后果 JetBrains教育版许可明确规定禁止用于商业盈利活动。任何基于教育版许可开发的商业项目都…

    2025年12月11日
    000
  • 白天夜晚模式切换后刷新页面就失效了,如何解决?

    白天/夜晚模式切换失效的解决方法 本文将解决白天/夜晚模式切换后刷新页面失效的问题。 问题在于,模式设置没有持久化保存,刷新页面后丢失了之前的选择。以下提供一种改进方案,利用cookie存储模式设置,并在页面加载时读取cookie恢复模式。 问题描述: 一个白天/夜晚模式切换按钮,刷新页面后,选择的…

    2025年12月11日
    000
  • 使用JetBrains教育许可证开发商业项目,会面临哪些风险?

    使用JetBrains教育许可证开发商业应用的风险分析 在企业级项目中使用JetBrains教育许可证存在诸多法律风险,务必谨慎。 违反许可协议 教育许可证明确禁止将基于其开发的软件用于商业用途或营利活动。 任何商业化行为,例如软件销售或商业交易,都将构成违反许可协议。 许可证合规性审查 虽然Jet…

    2025年12月11日
    000
  • PHP数组如何高效地添加子数组?

    高效php数组操作:向数组添加子数组的多种方法 本文将探讨在PHP中高效添加子数组到现有数组的几种方法,并比较其优缺点。 下图展示了本文将讨论的几种方法的对比。 方法一:使用foreach循环 这是最直观的方法,适合处理各种类型的子数组。 立即学习“PHP免费学习笔记(深入)”; $mainArra…

    2025年12月11日
    000
  • 网站代码中的神秘乱码是如何产生的以及如何解码?

    网页源代码中的神秘字符:成因与解密 浏览网页源代码时,经常会遇到一些看似毫无意义的字符组合,这就是所谓的“乱码”。 这些字符并非随机出现,而是经过编码的特殊字符或数据。 乱码的产生原因之一是HTML实体的使用。HTML使用实体来表示特殊字符,例如,引号(“)可以用实体 ” 表示。 另一种情况是使用U…

    2025年12月11日 好文分享
    000
  • Workerman客户端连接失败,onConnect回调未执行怎么办?

    Workerman客户端连接失败:onConnect回调未执行的排查指南 您的Workerman客户端无法连接服务器,且onConnect回调未执行?本文将帮助您分析并解决此问题。 可能原因如下: 连接参数错误: 请仔细检查连接地址和端口号是否正确,以及网络连接是否畅通。连接未在onWorkerSt…

    2025年12月11日
    000
  • Jar包部署后数据库连接失败,如何排查删除记录提示不存在的问题?

    Jar包部署后数据库连接异常及数据删除失败问题分析 在将项目打包成Jar包部署后,开发者遇到数据库连接问题,表现为删除记录时提示记录不存在,但数据库中实际存在该记录。本文将分析此问题并提供排查方案。 问题排查步骤 检查服务器日志: 仔细检查服务器后台日志,查找与数据库连接相关的错误信息。这些信息通常…

    2025年12月11日
    000
  • 前端开发如何最佳实践处理后端返回的特殊字符?

    前端开发:有效处理后端返回的特殊字符 为了确保前端页面内容正确显示,妥善处理后端返回的特殊字符至关重要。常见的特殊字符,例如HTML实体(如&),如果不加处理,可能会导致页面布局错乱或显示异常。 解决方案:利用字符串替换方法 最直接的处理方式是使用JavaScript的replace()方法…

    2025年12月11日
    000

发表回复

登录后才能评论
关注微信