当前位置: 首页 > article >正文

Fastjson枚举反序列化:当字符串不是枚举常量名时,会发生什么?

我们知道对外暴露的 HTTP RestAPI 接口通常使用 JSON 格式传输数据。服务端接收到数据后会将 JSON 字符串反序列化为对应的请求实体对象。我司灵工系统使用的是Fastjson-1.2.83作为序列化工具。在一次RestAPI开发过程中我忽然产生一个好奇当 VO 属性的类型是枚举(enum)而调用方传入的 JSON 字符串不是一个有效的枚举常量值时Fastjson 会如何处理带着这个疑问我决定一探究竟。一、测试序幕一个“意外”的异常我使用系统内现有的SourcePlatformEnum枚举进行测试。首先我写了一段代码将一个枚举实例序列化成 JSON 字符串String jsonString JSON.toJSONString(SourcePlatformEnum.YCX); System.out.println(jsonString);运行程序输出结果为YCX。这符合预期Fastjson 默认将枚举序列化为其名称字符串。接着我尝试将这个字符串反序列化回枚举对象String jsonString YCX; System.out.println(JSON.parseObject(jsonString, SourcePlatformEnum.class));这时运行程序却意外地抛出了JSONException异常com.alibaba.fastjson.JSONException: syntax error, pos 1, line 1, column 2YCX at com.alibaba.fastjson.parser.DefaultJSONParser.parse(DefaultJSONParser.java:1510) at com.alibaba.fastjson.parser.DefaultJSONParser.parse(DefaultJSONParser.java:1390) at com.alibaba.fastjson.serializer.StringCodec.deserialze(StringCodec.java:105) at com.alibaba.fastjson.serializer.StringCodec.deserialze(StringCodec.java:87) at com.alibaba.fastjson.parser.DefaultJSONParser.parseObject(DefaultJSONParser.java:705) at com.alibaba.fastjson.JSON.parseObject(JSON.java:394) at com.alibaba.fastjson.JSON.parseObject(JSON.java:298) at com.alibaba.fastjson.JSON.parseObject(JSON.java:588) at com.levy.openapi.TestMain.test(TestMain.java:18) ...问题出在哪里原来错误在于jsonString的赋值。YCX只是一个普通的 Java 字符串并非合法的 JSON 字符串。在 JSON 格式中字符串值必须由双引号包裹。正确的写法应该是String jsonString \YCX\;这个小小的插曲给了我一个重要的提醒在进行任何反序列化测试前首先要确保输入的JSON 格式是正确的。二、正式测试四种情况下的行为修正了格式错误后我使用fastjson-1.2.83系统地测试了四种常见情况结果如下用例输入的 JSON 字符串Fastjson 反序列化后的SourcePlatformEnum值Case 1nullnullCase 2(空字符串)nullCase 3YCX(有效的枚举常量名)SourcePlatformEnum.YCXCase 4INVALID_VALUE(无效的枚举常量名)nullCase 5null(无效的枚举常量名)nullCase 6ycX(大小写不一致)SourcePlatformEnum.YCX测试结果非常明确当输入为null或空字符串时反序列化结果为null。当输入是有效的枚举常量名(大小写不敏感)时能正确反序列化为对应的枚举实例。当输入是无效的枚举常量名时反序列化结果同样为null而不会抛出异常。这是Fastjson的默认行为。一句话总结为Fastjson 在枚举反序列化时对非法值采取了“静默返回 null”的策略而非抛出异常。注fastjson-1.2.83枚举反序列化器源码是com.alibaba.fastjson.parser.deserializer.EnumDeserializer。三、如何权衡API设计中能否使用枚举类型那么在实际的 API 接口设计中对于那些有对应枚举类的请求参数能否使用枚举作为其数据类型呢我认为关键在于如何理解并处理上面的Case 4。如果某个参数是极少变化的、明确的、必传的那么将其定义为枚举类型是非常合适的。这本身就是一种强类型的契约能清晰地告知调用方允许的取值范围。即使对方传了非法值在服务端接收到的是一个null我们可以在业务校验中轻松捕获并返回明确的参数错误提示。而对于那些非必填的、不定期会有变化的参数则可仍然使用基本Java类型。当然如果不介意非法值被静默转换为null定义为枚举类型在代码可读性上也有其价值。以我司商户API接口为例我们采用的是门面模式即所有 API 共用一个 URL通过必传的funCode参数来区分具体业务。这个funCode我们就将其定义为FunCodeEnum枚举类型。而如查询交易接口中的交易类型这个可选参数可以为基本Java类型这样当出现问题时通过原始入参值更容易排查。

相关文章:

Fastjson枚举反序列化:当字符串不是枚举常量名时,会发生什么?

我们知道,对外暴露的 HTTP RestAPI 接口通常使用 JSON 格式传输数据。服务端接收到数据后,会将 JSON 字符串反序列化为对应的请求实体对象。 我司灵工系统使用的是 Fastjson-1.2.83 作为序列化工具。在一次RestAPI开发过程中,我忽然产生一个好…...

如何给小龙虾设置定时任务:每日科技晨报

👇我的小册 54章教程:(小白零基础用Python量化股票分析小册) ,原价299,限时特价2杯咖啡,满100人涨10元。大家好,我是菜哥!目前小龙虾是可以干很多事情,我们的教程主要是集中自媒体运营,自媒体获…...

论文选题方法指导

定论文选题,是开启学术写作的第一步,也是最关键的一步。一个恰到好处的选题,能让后续的研究和撰写事半功倍;反之,则可能步步维艰。结合许多过来人的经验,我整理了一套系统性的选题方法、避坑指南以及实用工…...

迷你世界UGC3.0脚本Wiki排行榜、K/V数据介绍

迷你世界UGC3.0脚本WikiMenuOn this pageSidebar Navigation快速入门欢迎MOD、组件介绍什么是Lua编程组件介绍组件说明组件互相操作组件函数组件属性事件触发器事件管理组件事件管理函数库服务模块世界模块管理接口 World对象…...

Tomcat安装配置全攻略

好的!以下是一份详细的 Tomcat 安装及配置教程,适用于 Windows 和 Linux 系统,涵盖基础安装、环境配置、常见问题解决及优化建议。 一、准备工作 安装 JDK Tomcat 依赖 Java 环境,需先安装 JDK(推荐 JDK 8)…...

2026部署OpenClaw代理解决方案

这份华为 2026 年 2 月发布的《部署 OpenClaw 代理解决方案》(版本 1.0),核心是基于华为云 Flexus X 实例实现开源个人 AI 超级助手 OpenClaw(前称 Clawdbot)的一站式部署,同时明确了资源规划、部署流程、安…...

提示工程架构师实战:Agentic AI在物流调度中的路径优化案例

提示工程架构师实战:用Agentic AI破解物流调度路径优化难题 标题选项 提示工程架构师实战:Agentic AI在物流调度中的路径优化落地案例从0到1搭建Agentic物流系统:提示工程驱动的路径优化实战破解物流调度痛点:Agentic AI提示工程…...

Maya阿诺德渲染器aistandardsurface材质(万能材质)解析

物体&环境光【aiskydomelight】→【Color】→创建渲染节点(color数值条后面的小方块)→文件→图像名称→HDR(exr)贴图(Hypershade→aiskydomelight→特性编辑→aiskydomelightshape→visibility→camera0:渲染窗口背景为黑色&…...

**发散创新:基于稀疏模型的高效特征选择与代码实现详解**在现代机器学习和深度学习任务中,**稀疏模型**(Sparse M

发散创新:基于稀疏模型的高效特征选择与代码实现详解 在现代机器学习和深度学习任务中,稀疏模型(Sparse Model)已成为提升效率、降低资源消耗的重要手段。尤其在处理高维数据(如文本、图像、推荐系统)时&am…...

假外包真派遣:银行大楼里那群“不是员工”的打工人

在银行大厅、科技机房、后台办公区里,每天都在上演一幕最真实的荒诞剧: 一群人穿着统一工装,刷着同样的门禁,坐在同样的工位,做着银行最核心的科技业务。 但他们不是银行的人。 他们是银行外包员工。 是金融科技的隐形…...

2026年Ai建站指南:普通人如何通过自然语言搭建网站

AI并没有改变建站“呈现信息、处理数据”的本质,但极大地降低了门槛。通过邦云数据开发的AI建站工具,个人或企业可以快速构建出功能强大的网站,无需从头编写复杂代码。就像跟一个朋友聊聊天,把自己的网站说出来一样在模板建站时代…...

MySQL 教程(超详细,零基础可学、第一篇)

目录 一、MySQL数据库概述 二、MySQL 连接 1、使用 MySQL 二进制方式连接 2、使用 PHP 脚本连接 MySQL 三、MySQL 创建数据库 1、使用 mysqladmin 创建数据库 2、使用 PHP脚本 创建数据库 四、MySQL 删除数据库 1、使用 mysqladmin 删除数据库 2、使用 PHP 脚本删除数…...

《C++进阶之STL》【set/map 使用介绍】

关联容器的核心特征是: 非线性逻辑结构:通常基于树(如:红黑树)或哈希表实现,元素间通过键值的有序性或哈希映射建立关联 例如:二叉搜索树中左子树元素键值始终小于根节点,右子树元素…...

AI幻觉!掌握RAG技术,让你的AI回答不再“一本正经地胡说八道”!

这份教程系统地介绍了****生成式 AI 的运行机制及其核心缺陷,即由于概率预测本质而产生的幻觉问题。 为了克服 AI 缺乏实时事实依据的顽疾,深入阐述了 RAG(检索增强生成) 技术,详细梳理了从数据切片、向量化存储到检索…...

数据库高可用

数据库高可用:企业数据安全的生命线 在数字化时代,数据库作为企业核心数据的存储与管理中枢,其稳定性直接关系到业务连续性。一次数据库宕机可能导致数百万损失,甚至引发品牌信任危机。数据库高可用(High Availabilit…...

网络安全应急响应

网络安全应急响应:守护数字世界的安全防线 在数字化时代,网络安全威胁日益复杂,从数据泄露到勒索软件攻击,企业和个人都面临着前所未有的风险。网络安全应急响应(Incident Response, IR)作为应对这些威胁的…...

weixin238基于微信小程序的校园二手交易平台ssm(文档+源码)_kaic

第5章 系统实现进入到这个环节,也就可以及时检查出前面设计的需求是否可靠了。一个设计良好的方案在运用于系统实现中,是会帮助系统编制人员节省时间,并提升开发效率的。所以在系统的编程阶段,也就是系统实现阶段,对于…...

weixin237基于微信小程序的医院挂号预约系统ssm(文档+源码)_kaic

5 系统实现 系统实现部分就是将系统分析,系统设计部分的内容通过编码进行功能实现,以一个实际应用系统的形式展示系统分析与系统设计的结果。前面提到的系统分析,系统设计最主要还是进行功能,系统操作逻辑的设计,也包括…...

Java的密封类与模式匹配在有限继承体系中的类型安全设计

Java的密封类与模式匹配在有限继承体系中的类型安全设计 随着软件系统复杂度提升,类型安全成为现代Java开发的核心诉求。Java 16正式引入的密封类(Sealed Class)与模式匹配(Pattern Matching)特性,为构建有…...

Python的__complex__标准库

Python的__complex__标准库:解锁复数的编程魅力 在科学计算、信号处理或工程模拟中,复数运算常是不可或缺的一环。Python通过内置的complex类型和__complex__方法,为开发者提供了简洁而强大的复数处理能力。这一机制不仅支持基础的复数运算&…...

Spring Boot 自动装配加载逻辑

Spring Boot自动装配机制揭秘:简化开发的魔法引擎 在传统Spring应用中,开发者需要手动配置大量XML或Java Config来管理组件依赖,而Spring Boot通过自动装配(Auto-Configuration)彻底改变了这一局面。其核心思想是“约…...

3月18日(进阶9)

进阶9.矩形乘法 题目描述 给定一个N阶矩阵A&#xff0c;输出A的M次幂&#xff08;M是非负整数&#xff09;例如&#xff1a;A 1 23 4A的2次幂7 1015 22 代码 #include <iostream> #include <vector>using namespace std;// 定义矩阵类型&#xff0c;使用 long long…...

复杂三维山地环境下小龙虾优化算法COA求解多无人机动态避障路径规划研究附MATLAB代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。&#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室&#x1f447; 关注我领取海量matlab电子书和…...

Redis Cluster 高可用架构设计

Redis Cluster高可用架构设计解析 Redis作为高性能的内存数据库&#xff0c;其集群模式&#xff08;Redis Cluster&#xff09;通过分布式架构实现了数据分片与高可用性&#xff0c;成为企业级应用的热门选择。本文将深入探讨Redis Cluster的高可用设计&#xff0c;从核心机制…...

『NAS』在群晖部署无广聚合搜索引擎-SearXNG

点赞 关注 收藏 学会了 &#x1f4a1;整理了 NAS 专属玩法专栏&#xff0c;感兴趣的工友戳这里关注 &#x1f449; 《NAS邪修》 SearXNG 是一款开源的聚合搜索引擎工具&#xff0c;支持私有化部署&#xff0c;能整合多个主流搜索引擎的结果&#xff0c;且搜索页面无广告、无…...

RV1126 imx335 sensor调试

根据media-ctl -p -d /dev/media0输出&#xff1a;[rootATK-DLRV1126:/]# ls -l /tmp/test.nv12 -rw-r--r-- 1 root root 0 Jan 1 08:00 /tmp/test.nv12 [rootATK-DLRV1126:/]# media-ctl -p -d /dev/media0 Media controller API version 4.19.111 ​ Media device informati…...

【OpenClaw 全面解析:从零到精通】第 001 篇:一只“龙虾“如何改变了 AI 世界——OpenClaw 的诞生与历史背景

系列说明&#xff1a;本系列共计约 20 篇&#xff0c;全面介绍 OpenClaw 开源 AI 智能体框架&#xff0c;从历史背景到核心原理&#xff0c;从安装部署到应用生态。本文为系列第 001 篇&#xff0c;聚焦于 OpenClaw 的诞生历程与时代背景。 摘要 OpenClaw 是 2025 年底由奥地利…...

Python 3.13性能提升揭秘

该提问与当前博客内容无直接关联。 关于Python 3.13版本解决的问题&#xff0c;需要从Python语言本身的演进维度进行技术解析。Python 3.13作为2024年发布的重要版本&#xff0c;主要在解释器性能、语法特性和标准库三个方面进行了系统性优化。 解释器性能优化 自适应解释器…...

24:执行链完整闭环:从目标锁定到确认的全流程状态机

作者&#xff1a; HOS(安全风信子) 日期&#xff1a; 2026-03-07 主要来源平台&#xff1a; GitHub 摘要&#xff1a; 本文深入探讨如何构建一个从目标锁定到确认的全流程状态机&#xff0c;实现执行链的完整闭环。通过状态机的设计模式&#xff0c;我们可以将复杂的执行流程分…...

计算机进制转换

计算机进制转换一. 进制转换1.1 练习二. 原码、反码、补码、偏移码三. 练习一. 进制转换 二进制&#xff1a;逢二进一 十进制二进制001121031141005101611071118100091001101010 十进制转二进制 二进制转十进制 1.1 练习 十进制数转二进制&#xff1a;25 25 → 结果&#…...