百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

JSON工具之Jackson的使用详解

ztj100 2025-02-15 18:23 28 浏览 0 评论

1、Jackson的使用

Jackson 是当前用得比较广泛的,用来序列化和反序列化 json 的 Java 的开源框架。Jackson 社区相对比较活跃,更新速度也比较快, 从 Github 中的统计来看,Jackson 是最流行的 json 解析器之一 。 Spring MVC 的默认 json 解析器便是 Jackson。 Jackson 优点很多。 Jackson 所依赖的 jar 包较少 ,简单易用。与其他 Java 的 json 的框架 Gson 等相比, Jackson 解析大的 json 文件速度比较快;Jackson 运行时占用内存比较低,性能比较好;Jackson 有灵活的 API,可以很容易进行扩展和定制。

1.1Jackson的常用注解

注解

说明

@JsonIgnore

使用@JsonIgnore注解JSON序列化时将忽略该字段。示例:

@JsonIgnore
private String password;

@JsonProperty

用于属性,把属性的名称序列化时转换为另外一个名称。示例:

@JsonProperty("blog-remark")

private String blogRemark;

@JsonFormat

用于属性或者方法,把属性的格式序列化时转换成指定的格式。示例:

@JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
private Date createDate;

@JsonPropertyOrder

用于类, 指定属性在序列化时 json 中的顺序 , 示例:
@JsonPropertyOrder({ "birth_Date", "name" })

public class Person

@JsonCreator

用于构造方法,和 @JsonProperty 配合使用,适用有参数的构造方法。 示例:
@JsonCreator
public Person(@JsonProperty("name")String name) {…}

@JsonAnySetter

用于属性或者方法,设置未反序列化的属性名和值作为键值存储到 map 中
@JsonAnySetter

public void set(String key, Object value) {

map.put(key, value);

}

@JsonAnyGetter

用于方法 ,获取所有未序列化的属性
public Map any() { return map; }

1.2Jackson的简单应用

添加pom.xml配置信息:



  com.fasterxml.jackson.core
  jackson-core
  2.9.9


  com.fasterxml.jackson.core
  jackson-databind
  2.9.9


  com.fasterxml.jackson.core
  jackson-annotations
  2.9.9

创建UserInfo(用户信息实体类),用户JSON序列化示例使用。

示例要求:

(1)使用@JsonIgnore注解,序列化时忽略登录密码字段。

(2)使用@JsonProperty注解,将blogRemark字段序列化时转换为blog-remark。

(3)使用@JsonFormat注解,序列化时将日期格式化。

package com.demo.utils.entity;

import com.fasterxml.jackson.annotation.JsonFormat;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.databind.ObjectMapper;
import lombok.Data;

import java.util.Date;

/**
 * 用户信息实体类
 * @author luoxiang
 * @date 2022年01月13日 10:04 上午
 */
@Data
public class UserInfo
{
    /**
     * 用户名称
     */
    private String userName;

    /**
     * 登录密码
     * 使用@JsonIgnore注解
     * JSON序列化时将忽略该字段
     */
    @JsonIgnore
    private String password;

    /**
     * 博客地址
     */
    private String blogUrl;

    /**
     * 博客信息
     * 使用@JsonProperty注解
     * 把属性的名称序列化时转换为另外一个名称
     */
    @JsonProperty("blog-remark")
    private String blogRemark;

    /**
     * 创建时间
     * 使用@JsonFormat注解
     * 把属性的格式序列化时转换成指定的格式
     */
    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
    private Date createDate;

}

1.2.1 将实体类转换为JSON

/**
 * 将实体类转换为JSON
 * @author luoxiang
 */
@Test
public void entityToJson() throws Exception {
    //用户信息实体类
    UserInfo userInfo = new UserInfo();
    userInfo.setUserName("uncle_xiang的博客");
    userInfo.setPassword("123456");
    userInfo.setBlogUrl("https://blog.csdn.net/uncle_xiang");
    userInfo.setBlogRemark("您好,欢迎访问 uncle_xiang的博客");
    userInfo.setCreateDate(new Date());

    //将参数转换成JSON对象
    ObjectMapper mapper = new ObjectMapper();
    String json = mapper.writeValueAsString(userInfo);

    //打印结果
    System.out.println(json);
}

执行结果:

1.2.2 将JSON转换为实体类

/**
 * 将JSON转换为实体类
 * @author luoxiang
 */
@Test
public void jsonToEntity() throws Exception {
    //JSON内容
    String json = "{\"userName\":\"uncle_xiang的博客\",\"blogUrl\":\"https://blog.csdn.net/uncle_xiang\",\"createDate\":\"2022-01-13 10:07:55\",\"blog-remark\":\"您好,欢迎访问 uncle_xiang的博客\"}";

    //将JSON转换为实体类
    ObjectMapper mapper = new ObjectMapper();
    UserInfo  userInfo = mapper.readValue(json, UserInfo.class);

    //打印结果
    System.out.println("用户名称:" + userInfo.getUserName());
    System.out.println("登录密码:" + userInfo.getPassword());
    System.out.println("博客地址:" + userInfo.getBlogUrl());
    System.out.println("博客信息:" + userInfo.getBlogRemark());
    System.out.println("创建时间:" + userInfo.getCreateDate());
}

执行结果:

2、创建工具类

在项目中创建Jackson工具类(JacksonUtil.java)

package com.demo.utils.json;

import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.JavaType;
import com.fasterxml.jackson.databind.ObjectMapper;
import java.io.IOException;
import java.util.List;
import java.util.Map;
import java.util.Set;

/**
 * Jackson工具类
 * @author luoxiang
 * @date 2022年01月13日 10:13 上午
 */
public class JacksonUtil {

    private static ObjectMapper mapper = new ObjectMapper();

    /**
     * 将对象转换成JSON数据
     * @author luoxiang
     * @date 2022/1/13 10:15 上午
     * @param data   data对象
     * @return java.lang.String  JSON数据
     */
    public static String getBeanToJson(Object data){
        try {
            return mapper.writeValueAsString(data);
        } catch (JsonProcessingException e) {
            e.printStackTrace();
        }
        return null;
    }

    /**
     * 将JSON数据转换成对象
     * @author luoxiang
     * @date 2022/1/13 10:17 上午
     * @param jsonData  JSON数据
     * @param beanType  对象类型
     * @return T 对象
     */
    public static  T getJsonToBean(String jsonData,Class beanType){
        try {
            return mapper.readValue(jsonData, beanType);
        } catch (IOException e) {
            e.printStackTrace();
        }
        return null;
    }

    /**
     * 将JSON数据转换成列表
     * @author luoxiang
     * @date 2022/1/13 10:21 上午
     * @param jsonData JSON对象
     * @param beanType 对象类型
     * @return java.util.List 列表
     */
    public static  List getJsonToList(String jsonData, Class beanType){
        try {
            JavaType javaType = mapper.getTypeFactory().constructParametricType(List.class, beanType);
            return mapper.readValue(jsonData, javaType);
        } catch (IOException e) {
            e.printStackTrace();
        }
        return null;
    }

    /**
     * 将JSON数据转换成Set集合
     * @param jsonData JSON数据
     * @param elementType  元素类型
     * @param 
     * @return Set集合
     */
    public static  Set getJsonToSet(String jsonData, Class elementType){
        try {
            JavaType javaType = mapper.getTypeFactory().constructCollectionType(Set.class, elementType);
            return mapper.readValue(jsonData,javaType);
        } catch (IOException e) {
            e.printStackTrace();
        }
        return null;
    }

    /**
     * 将JSON数据转换成Map集合
     * @author luoxiang
     * @date 2022/1/13 10:28 上午
     * @param jsonData JSON数据
     * @param keyType  键类型
     * @param valueType 值类型
     * @return java.util.Map Map集合
     */
    public static  Map getJsonToMap(String jsonData, Class keyType, Class valueType){
        try {
            JavaType javaType = mapper.getTypeFactory().constructMapType(Map.class, keyType, valueType);
            return mapper.readValue(jsonData,javaType);
        } catch (IOException e) {
            e.printStackTrace();
        }
        return null;
    }
}

1.1将JSON数据转换成set集合。

/**
 * 将JSON数据转换成Set集合
 * @author luoxiang
 */
@Test
public void setTest(){
    Set userSet = new HashSet<>();
    userSet.add("uncle_xiang的博客");
    userSet.add("您好,欢迎访问 uncle_xiang的博客");
    userSet.add("https://blog.csdn.net/uncle_xiang");

    //将Set转化为JSON数据
    String json = JacksonUtil.getBeanToJson(userSet);
    System.out.println(json + "\n");

    //将JSON数据转换成Set集合
    Set jsonToSet = JacksonUtil.getJsonToSet(json,String.class);
    for(String item : jsonToSet) {
        System.out.println(item);
    }
}

执行结果:

2.2将JSON数据转换成Map集合。

/**
 * 将JSON数据转换成Map集合
 * @author luoxiang
 */
@Test
public void mapTest() {
    Map userMap = new HashMap<>();
    userMap.put("userName", "uncle_xiang的博客");
    userMap.put("blogUrl", "https://blog.csdn.net/uncle_xiang");
    userMap.put("blogRemark", "您好,欢迎访问 uncle_xiang的博客");

    //将map转化为JSON数据
    String json = JacksonUtil.getBeanToJson(userMap);

    //将JSON数据转换成Map集合
    Map jsonToMap = JacksonUtil.getJsonToMap(json, String.class, String.class);
    System.out.println("用户名称:" + jsonToMap.get("userName"));
    System.out.println("博客地址:" + jsonToMap.get("blogUrl"));
    System.out.println("博客备注:" + jsonToMap.get("blogRemark"));
}

执行结果:

相关推荐

sharding-jdbc实现`分库分表`与`读写分离`

一、前言本文将基于以下环境整合...

三分钟了解mysql中主键、外键、非空、唯一、默认约束是什么

在数据库中,数据表是数据库中最重要、最基本的操作对象,是数据存储的基本单位。数据表被定义为列的集合,数据在表中是按照行和列的格式来存储的。每一行代表一条唯一的记录,每一列代表记录中的一个域。...

MySQL8行级锁_mysql如何加行级锁

MySQL8行级锁版本:8.0.34基本概念...

mysql使用小技巧_mysql使用入门

1、MySQL中有许多很实用的函数,好好利用它们可以省去很多时间:group_concat()将取到的值用逗号连接,可以这么用:selectgroup_concat(distinctid)fr...

MySQL/MariaDB中如何支持全部的Unicode?

永远不要在MySQL中使用utf8,并且始终使用utf8mb4。utf8mb4介绍MySQL/MariaDB中,utf8字符集并不是对Unicode的真正实现,即不是真正的UTF-8编码,因...

聊聊 MySQL Server 可执行注释,你懂了吗?

前言MySQLServer当前支持如下3种注释风格:...

MySQL系列-源码编译安装(v5.7.34)

一、系统环境要求...

MySQL的锁就锁住我啦!与腾讯大佬的技术交谈,是我小看它了

对酒当歌,人生几何!朝朝暮暮,唯有己脱。苦苦寻觅找工作之间,殊不知今日之事乃我心之痛,难道是我不配拥有工作嘛。自面试后他所谓的等待都过去一段时日,可惜在下京东上的小金库都要见低啦。每每想到不由心中一...

MySQL字符问题_mysql中字符串的位置

中文写入乱码问题:我输入的中文编码是urf8的,建的库是urf8的,但是插入mysql总是乱码,一堆"???????????????????????"我用的是ibatis,终于找到原因了,我是这么解决...

深圳尚学堂:mysql基本sql语句大全(三)

数据开发-经典1.按姓氏笔画排序:Select*FromTableNameOrderByCustomerNameCollateChinese_PRC_Stroke_ci_as//从少...

MySQL进行行级锁的?一会next-key锁,一会间隙锁,一会记录锁?

大家好,是不是很多人都对MySQL加行级锁的规则搞的迷迷糊糊,一会是next-key锁,一会是间隙锁,一会又是记录锁。坦白说,确实还挺复杂的,但是好在我找点了点规律,也知道如何如何用命令分析加...

一文讲清怎么利用Python Django实现Excel数据表的导入导出功能

摘要:Python作为一门简单易学且功能强大的编程语言,广受程序员、数据分析师和AI工程师的青睐。本文系统讲解了如何使用Python的Django框架结合openpyxl库实现Excel...

用DataX实现两个MySQL实例间的数据同步

DataXDataX使用Java实现。如果可以实现数据库实例之间准实时的...

MySQL数据库知识_mysql数据库基础知识

MySQL是一种关系型数据库管理系统;那废话不多说,直接上自己以前学习整理文档:查看数据库命令:(1).查看存储过程状态:showprocedurestatus;(2).显示系统变量:show...

如何为MySQL中的JSON字段设置索引

背景MySQL在2015年中发布的5.7.8版本中首次引入了JSON数据类型。自此,它成了一种逃离严格列定义的方式,可以存储各种形状和大小的JSON文档,例如审计日志、配置信息、第三方数据包、用户自定...

取消回复欢迎 发表评论: