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

将 JSON 字符串转化为对象的详细笔记 (Java示例)

1. 主流 JSON 库的选择

在 Java 中,常用以下库进行 JSON 和对象之间的转换:

  • Jackson:Spring 默认集成,性能优异,支持流式解析。
  • FastJSON:阿里开发,速度快,但需注意版本安全性。
  • Gson:Google 维护,简单易用,语法简洁。
  • JSON-B:Java 标准 API(需依赖库如 Eclipse Yasson)。

2. 基本步骤

无论是哪种库,通用的转化步骤如下:

  1. 引入依赖
    在 Maven/Gradle 中添加对应 JSON 库的依赖。

  2. 定义目标类
    创建 Java 类,属性与 JSON 字段对应(支持嵌套对象或数组)。

  3. 调用 API 转化
    使用库的 API 将 JSON 字符串转为对象。


示例 1:使用 FastJSON

依赖引入(Maven)

<XML>

<dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>2.0.23</version>
</dependency>
代码实现

<JAVA>

public class User {private String name;private int age;// 字段名与 JSON 中的 key 一致(或使用 @JSONField 注解)// 需要 getter/setter
}// 示例 JSON 字符串
String jsonStr = "{\"name\": \"John\", \"age\": 30}";// 转换
User user = JSON.parseObject(jsonStr, User.class);
关键注解
  • @JSONField(name = "json_key"):映射 JSON 字段名。

<JAVA>

public class WechatUser {@JSONField(name = "openid")private String openId;
}

示例 2:使用 Jackson

依赖引入(Spring Boot 默认包含)

<XML>

<dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId><version>2.13.3</version>
</dependency>
代码实现

<JAVA>

ObjectMapper mapper = new ObjectMapper();// 将 JSON 转为对象
User user = mapper.readValue(jsonStr, User.class);// 处理复杂 JSON(如嵌套对象或数组)
String nestedJson = "{\"name\": \"John\", \"address\": {\"city\": \"Paris\"}}";
User user = mapper.readValue(nestedJson, User.class);
关键注解
  • @JsonProperty("json_key"):映射 JSON 字段名。
  • @JsonIgnore:忽略字段。

示例 3:使用 Gson

依赖引入

<XML>

<dependency><groupId>com.google.code.gson</groupId><artifactId>gson</artifactId><version>2.8.9</version>
</dependency>
代码实现

<JAVA>

Gson gson = new Gson();// JSON 转为对象
User user = gson.fromJson(jsonStr, User.class);// 处理复杂结构
List<User> users = gson.fromJson("[{\"name\": \"John\"}]", new TypeToken<List<User>>(){}.getType());
关键配置
  • @SerializedName("json_key"):字段映射注解。

<JAVA>

public class WechatUser {@SerializedName("openid")private String openId;
}

3. 常见问题及解决

问题 1:字段名不匹配
  • 场景:JSON 中的 openid vs Java 类的 openId
  • 解决
    使用库的注解(如 @JsonProperty@JSONField@SerializedName)。
问题 2:缺少默认构造函数
  • 报错No default constructor for XXX.
  • 解决:确保类有一个无参构造器。
问题 3:处理日期格式
  • 场景:JSON 中的日期字符串转为 LocalDateTime
  • 解决
    自定义序列化/反序列化规则(如 @JsonFormat 注解)。

<JAVA>

@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime createTime;
问题 4:嵌套对象或集合
  • 示例 JSON

    <JSON>

    {"name": "John","orders": [{"id": 1}, {"id": 2}]
    }
  • 对象定义

    <JAVA>

    public class User {private String name;private List<Order> orders;
    }public class Order {private int id;
    }

4. 安全性注意事项

  • 避免反序列化漏洞:禁用 AutoType 特性(FastJSON 需设置 ParserConfig.getGlobalInstance().setSafeMode(true);)。
  • 校验 JSON 来源:确保字符串来自可信接口,避免注入攻击。

5. 性能优化

  • 缓存 ObjectMapper 或 Gson 实例:避免重复创建。
  • 使用流式 API:处理大 JSON 文件时,用 JsonParser 逐步解析(如 Jackson 的 JsonFactory)。

代码模板(通用)

<JAVA>

try {// 使用 JacksonObjectMapper mapper = new ObjectMapper();MyObject obj = mapper.readValue(jsonStr, MyObject.class);// 使用 GsonGson gson = new Gson();MyObject obj = gson.fromJson(jsonStr, MyObject.class);// 使用 FastJSONMyObject obj = JSON.parseObject(jsonStr, MyObject.class);
} catch (JsonProcessingException e) {// 处理格式错误
} catch (Exception e) {// 其他异常(如字段缺失)
}

通过掌握不同库的特性及常见问题处理,可高效完成 JSON 字符串到对象的转化,适用于 API 响应解析、配置文件读取等场景。

http://www.xdnf.cn/news/686.html

相关文章:

  • 【AI量化第26篇】以配置为核心的工程化研究管理——基于miniQMT的量化交易回测系统开发实记
  • 15. 三数之和
  • 计算机网络中的网络层:架构、功能与重要性
  • llama factory
  • springboot+vue3+mysql+websocket实现的即时通讯软件
  • C++数组栈与链表栈
  • 软考高级系统架构设计师-第16章 数学与经济管理
  • 切换 Python 版本(配置path方式,含trae)
  • 一个最简单的 Model Context Protocol 的例子
  • Halcon应用:相机标定
  • C++入门篇(下)
  • 线性DP:最长上升子序列(可不连续,数组必须连续)
  • Matlab 复合模糊PID
  • NumPy:数值计算基础与高性能数组操作
  • 如何使用人工智能大模型,免费快速写工作总结?
  • Linux基础指令 补充(自用)
  • 【微知】服务器如何获取服务器的SN序列号信息?(dmidecode -t 1)
  • Origin将双Y轴柱状图升级为双向分组柱状图
  • 二、在springboot 中使用 AIService
  • 【JAVA EE初阶】多线程(1)
  • 代码随想录算法训练营第五十三天 | 105.有向图的完全可达性 106.岛屿的周长
  • 如何轻松实现用户充值系统的API自动化测试
  • QML、Qt Quick 、Qt Quick Controls 2
  • 如何成为Prompt工程师:学习路径、核心技能与职业发展
  • STM32时钟树
  • 微信小程序中使用h5页面预览图片、视频、pdf文件
  • PHP伪协议读取文件
  • Matlab 步进电机传递函数模糊pid
  • langchain-nextjs-template 模板安装与配置
  • 【文献阅读】EndoNet A Deep Architecture for Recognition Tasks on Laparoscopic Videos