如何处理Jackson反序列化map和set等复杂类型的数据难题?

2026-05-16 02:571阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计628个文字,预计阅读时间需要3分钟。

如何处理Jackson反序列化map和set等复杂类型的数据难题?

在处理工作中遇到的问题时,我简单用代码复现了一下。这是一个Map,其中value又是一个Set,导致反序序列化报错。以下是测试代码:

java@Testpublic void test10() throws Exception { // 准备一下数据 Map map=new HashMap();}

工作中遇到了这个问题,我简单的用代码复现一下,就是一个map,value又为一个set,导致反序列化报错

@Test public void test10() throws Exception { //准备一下数据 Map<String, Set<String>> map = new HashMap<>(); map.put("aaa",new HashSet<String>(){{add("111");add("222");}}); ObjectMapper om = new ObjectMapper(); String str01 = om.writeValueAsString(map); //System.out.println(str01); // {"aaa":["111","222"]} // 正常反序列化,未报错 Map<String, Set<String>> map01 = om.readValue(str01, Map.class); // 取值的时候就会报错了 Set<String> aaa = map01.get("aaa"); }

报错:

java.lang.ClassCastException: java.util.ArrayList cannot be cast to java.util.Set

报错信息:无法将list转为set。

再拓展开来,其实当你的Map里面的对象如果是object类型的自定义类型,其实都会报错,无法被强转,那么我们就需要指定jackson反序列化为什么类型,而不是让它自主决定反序列化成什么类型,需要用到TypeReference,直接上代码。

@Test public void test10() throws Exception { //准备一下数据 Map<String, Set<String>> map = new HashMap<>(); map.put("aaa",new HashSet<String>(){{add("111");add("222");}}); ObjectMapper om = new ObjectMapper(); String str01 = om.writeValueAsString(map); //System.out.println(str01); // {"aaa":["111","222"]} Map<String, Set<String>> m = om.readValue(str01, new TypeReference<HashMap<String, Set<String>>>() {}); Set<String> aaa = m.get("aaa"); System.out.println(aaa instanceof HashSet); // true }

补充知识:Jackson 处理复杂类型(List,map)两种方法

方法一

String jsonString="[{'id':'1'},{'id':'2'}]"; ObjectMapper mapper = new ObjectMapper(); JavaType javaType = mapper.getTypeFactory().constructParametricType(List.class, Bean.class); //如果是Map类型 mapper.getTypeFactory().constructParametricType(HashMap.class,String.class, Bean.class); List<Bean> lst = (List<Bean>)mapper.readValue(jsonString, javaType);

当转换完成时一定要用这个转换对象,如果不用这个对象是没有值的.如下,当我打印时这个projects对象才有值,否则projects无值 .

List<AlertProjectInfo> projects = mapper.readValue(subProject, mapper.getTypeFactory().constructCollectionType(List.class, AlertProjectInfo.class)); System.out.println(projects.size());

方法二

如何处理Jackson反序列化map和set等复杂类型的数据难题?

String jsonString="[{'id':'1'},{'id':'2'}]"; ObjectMapper mapper = new ObjectMapper(); List<Bean> beanList = mapper.readValue(jsonString, new TypeReference<List<Bean>>() {});

以上这篇解决Jackson反序列化map,set等复杂类型问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持易盾网络。

本文共计628个文字,预计阅读时间需要3分钟。

如何处理Jackson反序列化map和set等复杂类型的数据难题?

在处理工作中遇到的问题时,我简单用代码复现了一下。这是一个Map,其中value又是一个Set,导致反序序列化报错。以下是测试代码:

java@Testpublic void test10() throws Exception { // 准备一下数据 Map map=new HashMap();}

工作中遇到了这个问题,我简单的用代码复现一下,就是一个map,value又为一个set,导致反序列化报错

@Test public void test10() throws Exception { //准备一下数据 Map<String, Set<String>> map = new HashMap<>(); map.put("aaa",new HashSet<String>(){{add("111");add("222");}}); ObjectMapper om = new ObjectMapper(); String str01 = om.writeValueAsString(map); //System.out.println(str01); // {"aaa":["111","222"]} // 正常反序列化,未报错 Map<String, Set<String>> map01 = om.readValue(str01, Map.class); // 取值的时候就会报错了 Set<String> aaa = map01.get("aaa"); }

报错:

java.lang.ClassCastException: java.util.ArrayList cannot be cast to java.util.Set

报错信息:无法将list转为set。

再拓展开来,其实当你的Map里面的对象如果是object类型的自定义类型,其实都会报错,无法被强转,那么我们就需要指定jackson反序列化为什么类型,而不是让它自主决定反序列化成什么类型,需要用到TypeReference,直接上代码。

@Test public void test10() throws Exception { //准备一下数据 Map<String, Set<String>> map = new HashMap<>(); map.put("aaa",new HashSet<String>(){{add("111");add("222");}}); ObjectMapper om = new ObjectMapper(); String str01 = om.writeValueAsString(map); //System.out.println(str01); // {"aaa":["111","222"]} Map<String, Set<String>> m = om.readValue(str01, new TypeReference<HashMap<String, Set<String>>>() {}); Set<String> aaa = m.get("aaa"); System.out.println(aaa instanceof HashSet); // true }

补充知识:Jackson 处理复杂类型(List,map)两种方法

方法一

String jsonString="[{'id':'1'},{'id':'2'}]"; ObjectMapper mapper = new ObjectMapper(); JavaType javaType = mapper.getTypeFactory().constructParametricType(List.class, Bean.class); //如果是Map类型 mapper.getTypeFactory().constructParametricType(HashMap.class,String.class, Bean.class); List<Bean> lst = (List<Bean>)mapper.readValue(jsonString, javaType);

当转换完成时一定要用这个转换对象,如果不用这个对象是没有值的.如下,当我打印时这个projects对象才有值,否则projects无值 .

List<AlertProjectInfo> projects = mapper.readValue(subProject, mapper.getTypeFactory().constructCollectionType(List.class, AlertProjectInfo.class)); System.out.println(projects.size());

方法二

如何处理Jackson反序列化map和set等复杂类型的数据难题?

String jsonString="[{'id':'1'},{'id':'2'}]"; ObjectMapper mapper = new ObjectMapper(); List<Bean> beanList = mapper.readValue(jsonString, new TypeReference<List<Bean>>() {});

以上这篇解决Jackson反序列化map,set等复杂类型问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持易盾网络。