ObjectMapper 对象和json相互转换

本文介绍了Jackson库的核心类ObjectMapper,用于Java对象与JSON之间的转换。内容包括配置ObjectMapper进行序列化和反序列化的设置,如日期格式、空值处理等,并提供了将对象转换为JSON字符串以及将JSON字符串转换回对象的方法。此外,还展示了如何处理集合类型的转换,并通过示例代码进行了演示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、ObjectMapper

ObjectMapper类是Jackson库的主要类。它提供一些功能将转换成Java对象匹配JSON结构,反之亦然。它使用JsonParser和JsonGenerator的实例实现JSON实际的读/写。

maven依赖:

     <dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.8.3</version>
</dependency>

二、代码


import com.google.common.collect.Lists;
import com.mmall.pojo.User;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.codehaus.jackson.map.DeserializationConfig;
import org.codehaus.jackson.map.ObjectMapper;
import org.codehaus.jackson.map.SerializationConfig;
import org.codehaus.jackson.map.annotate.JsonSerialize;
import org.codehaus.jackson.type.JavaType;
import org.codehaus.jackson.type.TypeReference;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
/**
 * json转换工具类
 */
@Slf4j
public class JsonUtil {

    private static ObjectMapper objectMapper = new ObjectMapper();
    static {
        //将对象的所有字段全部列入
        objectMapper.setSerializationInclusion(JsonSerialize.Inclusion.ALWAYS);

        //取消默认转换timestamps形式,false使用日期格式转换,true不使用日期转换,结果是时间的数值157113793535
        objectMapper.configure(SerializationConfig.Feature.WRITE_DATE_KEYS_AS_TIMESTAMPS,false); //默认值true

        //忽略空Bean转json的错误
        objectMapper.configure(SerializationConfig.Feature.FAIL_ON_EMPTY_BEANS,false);

        //所有的日期格式统一样式: yyyy-MM-dd HH:mm:ss
        objectMapper.setDateFormat(new SimpleDateFormat(DateTimeUtil.STANDARD_FORMAT));

        //忽略 在json字符串中存在,但是在对象中不存在对应属性的情况,防止错误。
        // 例如json数据中多出字段,而对象中没有此字段。如果设置true,抛出异常,因为字段不对应;false则忽略多出的字段,默认值为null,将其他字段反序列化成功
        objectMapper.configure(DeserializationConfig.Feature.FAIL_ON_NULL_FOR_PRIMITIVES,false);

    }

    //将单个对象转换成json格式的字符串(没有格式化后的json)
    public static <T> String obj2String(T obj){
        if (obj == null){
            return null;
        }
        try {
            return obj instanceof String ? (String) obj:objectMapper.writeValueAsString(obj);
        } catch (IOException e) {
            log.warn("Parse object to String error", e);
            return null;
        }
    }

    //将单个对象转换成json格式的字符串(格式化后的json)
    public static <T> String obj2StringPretty(T obj){
        if (obj == null){
            return null;
        }
        try {
            return obj instanceof String ? (String) obj:objectMapper.writerWithDefaultPrettyPrinter().writeValueAsString(obj);
        } catch (IOException e) {
            log.warn("Parse object to String error", e);
            return null;
        }
    }
    //将json形式的字符串数据转换成单个对象
    public static <T> T string2Obj(String str, Class<T> clazz){
        if (StringUtils.isEmpty(str) || clazz == null){
            return null;
        }
        try {
            return clazz.equals(String.class) ? (T) str : objectMapper.readValue(str,clazz);
        } catch (IOException e) {
            log.warn("Parse object to Object error", e);
            return null;
        }
    }

    //将json形式的字符串数据转换成多个对象
    public static <T> T string2Obj(String str, TypeReference<T> typeReference){
        if (StringUtils.isEmpty(str) || typeReference == null){
            return null;
        }
        try {
            return typeReference.getType().equals(String.class) ? (T) str : (T) objectMapper.readValue(str, typeReference);
        } catch (IOException e) {
            log.warn("Parse object to Object error", e);
            return null;
        }
    }

    //将json形式的字符串数据转换成多个对象
    public static <T> T string2Obj(String str, Class<T> collectionClass, Class<?>... elementClasses){
        JavaType javaType = objectMapper.getTypeFactory().constructParametricType(collectionClass,elementClasses);
        try {
            return objectMapper.readValue(str, javaType);
        } catch (IOException e) {
            log.warn("Parse object to Object error", e);
            return null;
        }
    }

    //测试
    public static void main(String[] args) {
//        User user1 = new User();
//        user1.setId(1);
//        user1.setUsername("wangjun1");
//        user1.setCreateTime(new Date());
//        String user1JsonPretty = JsonUtil.obj2StringPretty(user1);
//        log.info("user1JsonPretty:{}", user1JsonPretty);
//        User user2 = new User();
//        user2.setId(2);
//        user2.setUsername("wangjun2");
//
//        String user1Json = JsonUtil.obj2String(user1);
//
//        String user1JsonPretty = JsonUtil.obj2StringPretty(user1);
//
//        log.info("user1Json:{}", user1Json);
//
//        log.info("user1JsonPretty:{}", user1JsonPretty);
//
//
//        User user = JsonUtil.string2Obj(user1Json, User.class);
//        System.out.println(user.getUsername());
//
//        List<User> userList = Lists.newArrayList();
//        userList.add(user1);
//        userList.add(user2);
//
//        String userListStr = JsonUtil.obj2StringPretty(userList);
//
//        log.info("==================");
//        log.info(userListStr);
//
//        List<User> userListObj1 = JsonUtil.string2Obj(userListStr, new TypeReference<List<User>>() {
//        });
//        System.out.println(userListObj1);
//
//        List<User> userListObj2 = JsonUtil.string2Obj(userListStr,List.class,User.class);
//        System.out.println(userListObj2);
//        System.out.println("end");
    }
}

三、扩展

利用对象转换json。可以做单点登录,将用户的信息转换为json数据,作为redis的value值;将用户的sessionid作为key,存储到redis中。

### 使用 Jackson ObjectMapper 将集合对象转换JSON 字符串 在使用 Jackson 的 `ObjectMapper` 时,可以轻松地将集合对象(如 `List` 或 `Map`)转换JSON 字符串。以下是详细的说明代码示例: #### 1. 将 `Map` 转换JSON 字符串 通过 `ObjectMapper` 的 `writeValueAsString()` 方法,可以将一个 `Map` 对象转换JSON 格式的字符串。 ```java import com.fasterxml.jackson.databind.ObjectMapper; import java.util.HashMap; import java.util.Map; public class MapToJsonExample { public static void main(String[] args) throws Exception { // 创建一个 Map 对象 Map<String, Object> map = new HashMap<>(); map.put("name", "Alice"); map.put("age", 25); // 初始化 ObjectMapper 实例 ObjectMapper mapper = new ObjectMapper(); // 将 Map 转换JSON 字符串 String jsonString = mapper.writeValueAsString(map); // 输出结果 System.out.println(jsonString); // {"name":"Alice","age":25} } } ``` 此方法展示了如何将一个简单的 `Map` 转换JSON 字符串[^4]。 #### 2. 将 `List` 转换JSON 字符串 同样,`writeValueAsString()` 方法也可以用于将 `List` 对象转换JSON 字符串。 ```java import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.databind.ObjectMapper; import java.util.ArrayList; import java.util.List; public class ListToJsonExample { public static void main(String[] args) throws JsonProcessingException { // 创建一个 List 对象 List<String> list = new ArrayList<>(); list.add("Apple"); list.add("Banana"); list.add("Cherry"); // 初始化 ObjectMapper 实例 ObjectMapper mapper = new ObjectMapper(); // 将 List 转换JSON 字符串 String jsonString = mapper.writeValueAsString(list); // 输出结果 System.out.println(jsonString); // ["Apple","Banana","Cherry"] } } ``` 这段代码演示了如何将一个包含字符串的 `List` 转换JSON 数组格式的字符串[^4]。 #### 3. 自定义日期格式处理 如果集合中包含日期类型的字段,可以通过设置 `ObjectMapper` 的日期格式来确保正确的 JSON 输出。 ```java import com.fasterxml.jackson.databind.ObjectMapper; import java.text.SimpleDateFormat; import java.util.Date; import java.util.HashMap; import java.util.Map; public class DateToJsonExample { public static void main(String[] args) throws Exception { // 创建一个 Map 对象,并添加日期字段 Map<String, Object> map = new HashMap<>(); map.put("date", new Date()); // 初始化 ObjectMapper 实例 ObjectMapper mapper = new ObjectMapper(); // 设置日期格式 SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); mapper.setDateFormat(dateFormat); // 将 Map 转换JSON 字符串 String jsonString = mapper.writeValueAsString(map); // 输出结果 System.out.println(jsonString); // {"date":"2023-03-01 12:34:56"} } } ``` 上述代码展示了如何自定义日期格式以避免默认格式化问题[^5]。 ### 注意事项 - 确保在项目中引入了 Jackson 库的相关依赖。 - 如果集合中的对象包含复杂的数据类型(如嵌套对象或数组),Jackson 会自动递归解析这些对象并生成相应的 JSON 结构[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一写代码就开心

你的打赏将是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值