json 转换工具类

这是一个基于Jackson库的Java工具类,用于实现对象与JSON字符串之间的转换。它配置了序列化和反序列化的各种选项,如处理空Bean、忽略未知属性、设置日期格式,并支持Java 8的时间模块。该类提供了将对象转换为JSON字符串以及将JSON字符串解析为对象的方法。
摘要由CSDN通过智能技术生成

import com.fasterxml.jackson.annotation.JsonInclude.Include;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.DeserializationFeature;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.SerializationFeature;
import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule;
import java.io.IOException;
import java.text.SimpleDateFormat;
import lombok.extern.slf4j.Slf4j;

/**

  • 基于Jackson的JSON转换工具类

  • @author ye17186

  • @version 2018/6/29 12:06
    */
    @Slf4j
    public class JsonUtils {

    private static ObjectMapper om = new ObjectMapper();

    static {

     // 对象的所有字段全部列入,还是其他的选项,可以忽略null等
     om.setSerializationInclusion(Include.ALWAYS);
     // 设置Date类型的序列化及反序列化格式
     om.setDateFormat(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"));
    
     // 忽略空Bean转json的错误
     om.configure(SerializationFeature.FAIL_ON_EMPTY_BEANS, false);
     // 忽略未知属性,防止json字符串中存在,java对象中不存在对应属性的情况出现错误
     om.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
    
     // 注册一个时间序列化及反序列化的处理模块,用于解决jdk8中localDateTime等的序列化问题
     om.registerModule(new JavaTimeModule());
    

    }

    /**

    • 对象 => json字符串

    • @param obj 源对象
      */
      public static String toJson(T obj) {

      String json = null;
      if (obj != null) {
      try {
      json = om.writeValueAsString(obj);
      } catch (JsonProcessingException e) {
      log.warn(e.getMessage(), e);
      throw new IllegalArgumentException(e.getMessage());
      }
      }
      return json;
      }

    /**

    • json字符串 => 对象

    • @param json 源json串

    • @param clazz 对象类

    • @param 泛型
      */
      public static T parse(String json, Class clazz) {

      return parse(json, clazz, null);
      }

    /**

    • json字符串 => 对象

    • @param json 源json串

    • @param type 对象类型

    • @param 泛型
      */
      public static T parse(String json, TypeReference type) {

      return parse(json, null, type);
      }

    /**

    • json => 对象处理方法


    • 参数clazz和type必须一个为null,另一个不为null


    • 此方法不对外暴露,访问权限为private

    • @param json 源json串

    • @param clazz 对象类

    • @param type 对象类型

    • @param 泛型
      */
      private static T parse(String json, Class clazz, TypeReference type) {

      T obj = null;
      if (!StringUtils.isEmpty(json)) {
      try {
      if (clazz != null) {
      obj = om.readValue(json, clazz);
      } else {
      obj = om.readValue(json, type);
      }
      } catch (IOException e) {
      log.warn(e.getMessage(), e);
      throw new IllegalArgumentException(e.getMessage());
      }
      }
      return obj;
      }
      }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值