直接说结论方便一目了然:

1. 简单的直接Bean.class

2. 复杂的用 TypeReference

这样就完事了。

public class TestMain2 {
public static void main(String[] args) throws JsonProcessingException { /*
首先说明 readValue 针对String 一共有3个重载,如下: public <T> T readValue(String content, Class<T> valueType);简单型,就是 直接 UserBase.class 就可。 public <T> T readValue(String content, TypeReference<T> valueTypeRef);复杂的可以 用这个 public <T> T readValue(String content, JavaType valueType);这个书写起来比较麻烦,就不说明了,不常用,前2个已经彻底满足了。 */ ObjectMapper objectMapper = new ObjectMapper();
String json1 = "{\"userName\":\"小李飞刀\",\"age\":18,\"addTime\":1591851786568}";
String json2 = "[{\"userName\":\"小李飞刀\",\"age\":18,\"addTime\":123}, {\"userName\":\"小李飞刀2\",\"age\":182,\"addTime\":1234}]"; //1.最简单的常用方法,直接将一个json转换成实体类
UserBase userBase1 = objectMapper.readValue(json1, UserBase.class); //简单类型的时候,这样最方便
System.out.println("简单: " + userBase1.getUserName());
//用 TypeReference 也可以,但是麻烦 不如第一种直接 TypeReference 主要针对繁杂类型
//UserBase userBase2 = objectMapper.readValue(json1, new TypeReference<UserBase>() {}); //2.把Json转换成map,必须使用 TypeReference , map的类型定义 可以根据实际情况来定,比如若值都是String那么就可以 Map<String, String>
Map<String, Object> userBaseMap = objectMapper.readValue(json1, new TypeReference<Map<String, Object>>() {});
System.out.println("map: " + userBaseMap.get("userName")); //3.list<Bean>模式,必须用 TypeReference
List<UserBase> userBaseList = objectMapper.readValue(json2, new TypeReference<List<UserBase>>() {});
System.out.println("list: " + userBaseList.get(0).getUserName()); //4.Bean[] 数组,必须用 TypeReference
UserBase[] userBaseAry = objectMapper.readValue(json2, new TypeReference<UserBase[]>() {});
System.out.println("ary: " + userBaseAry[0].getUserName());
}
}

==========================================================下面是详细的秒数==================================================

方法1,针对简单类型,有实体类的json,直接转换成单个实体类,上代码:

首先是一个实体类UserBase:

public class UserBase {

    /**
* 用户名
*/
private String userName; /**
* 年龄
*/
private Integer age; /**
* 增加时间
*/
private Date addTime; public String getUserName() {
return userName;
} public void setUserName(String userName) {
this.userName = userName;
} public Integer getAge() {
return age;
} public void setAge(Integer age) {
this.age = age;
} public Date getAddTime() {
return addTime;
} public void setAddTime(Date addTime) {
this.addTime = addTime;
}
}

public class TestMain2 {
public static void main(String[] args) throws JsonProcessingException {

/*
1.最简单的常用方法,直接将一个json转换成实体类
*/
ObjectMapper objectMapper = new ObjectMapper();
String json = "{\"userName\":\"小李飞刀\",\"age\":18,\"addTime\":1591851786568}";

//这里需要这么写,
UserBase userBase = objectMapper.readValue(json, UserBase.class); //简单类型的时候,这样最方便

UserBase userBase1 = objectMapper.readValue(json, new TypeReference<UserBase>() {}); //这样也可以,TypeReference主要针对复杂类型

System.out.println(userBase.getUserName());
System.out.println(userBase1.getUserName());
}
}

2. 若是map呢, 应该怎么用会怎样??以下开始举例:

public class TestMain3 {
public static void main(String[] args) throws JsonProcessingException {
ObjectMapper objectMapper = new ObjectMapper(); //注意这里键名和键值都是String类型的
Map<String, String> map = new HashMap<>();
map.put("name", "小李飞刀");
map.put("sex", "男"); //先生成一个json方便理解
String json = objectMapper.writeValueAsString(map);
System.out.println(json);//{"sex":"男","name":"小李飞刀"} /*
开始反序列化
*/
Map<String,String> map1 = new HashMap<>();
//我之前是这么写的直接 Map.class 总觉得不妥,感觉他用了默认的推断,然后程序也能正常运行
map1 = objectMapper.readValue(json, Map.class);
System.out.println(map1.get("name")); }
}

我们调试一下代码看下,

显然这种方式,不好,1. 编译时 会有 泛型警告。2. 不完美 虽然能用,但是不要这样。那么 Map时 应该如何 反序列化呢,看如下代码:

map1 = objectMapper.readValue(json, new TypeReference<Map<String, String>>() {}); //用这个

我们来调试看下,这次是否清晰说明了 map1的类型。

 

好了,干完了 map,接下来还有一个常用的List<Bean> ,我们调试看下:

public class TestMain4 {
public static void main(String[] args) throws JsonProcessingException {
ObjectMapper objectMapper = new ObjectMapper(); String json = "[{\"userName\":\"小李飞刀\",\"age\":18,\"addTime\":123}, {\"userName\":\"小李飞刀2\",\"age\":182,\"addTime\":1234}]"; List<UserBase> userBaseList = objectMapper.readValue(json, List.class); System.out.println(userBaseList.get(0).getUserName());
}
}

先不调试了,需要这么写:

List<UserBase> userBaseList = objectMapper.readValue(json, new TypeReference<List<UserBase>>() {});

上面是直接把Json, 转换成 List<bean>,关于直接转换成 Bean数组的问题即,直接把 json转换成 bean[],也是用 TypeReference 就可:看如下代码:

public class TestMain4 {
public static void main(String[] args) throws JsonProcessingException {
ObjectMapper objectMapper = new ObjectMapper(); String json = "[{\"userName\":\"小李飞刀\",\"age\":18,\"addTime\":123}, {\"userName\":\"小李飞刀2\",\"age\":182,\"addTime\":1234}]"; UserBase[] userBaseAry = objectMapper.readValue(json, new TypeReference<UserBase[]>() {}); System.out.println(userBaseAry[0].getUserName());
}
}

===================================================================================================

由于 objectMapper 一共有3个重载,我们已经讲了 2个,还有一个 我们看下他的用法,这个不常用,以后尽量少用 会不用,写代码 没有上面2种 来的直接和方便。

复制代码
ObjectMapper mapper = new ObjectMapper();
  // 排除json字符串中实体类没有的字段
  objectMapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES,false); String json = "[{\"name\":\"a\",\"password\":\"345\"},{\"name\":\"b\",\"password\":\"123\"}]"; //第一种方法
List<User> list = mapper.readValue(json, new TypeReference<List<User>>(){/**/}); //第二种方法
JavaType javaType = mapper.getTypeFactory().constructCollectionType(List.class, User.class);
List<User> list2 = mapper.readValue(json, javaType);
复制代码 Jackson,我感觉是在Java与Json之间相互转换的最快速的框架,当然Google的Gson也很不错,但是参照网上有人的性能测试,看起来还是Jackson比较快一点 Jackson处理一般的JavaBean和Json之间的转换只要使用ObjectMapper 对象的readValue和writeValueAsString两个方法就能实现。但是如果要转换复杂类型Collection如 List<YourBean>,那么就需要先反序列化复杂类型 为泛型的Collection Type。 如果是ArrayList<YourBean>那么使用ObjectMapper 的getTypeFactory().constructParametricType(collectionClass, elementClasses); 如果是HashMap<String,YourBean>那么 ObjectMapper 的getTypeFactory().constructParametricType(HashMap.class,String.class, YourBean.class); 复制代码
public final ObjectMapper mapper = new ObjectMapper(); public static void main(String[] args) throws Exception{
JavaType javaType = getCollectionType(ArrayList.class, YourBean.class);
List<YourBean> lst = (List<YourBean>)mapper.readValue(jsonString, javaType);
}
/**
* 获取泛型的Collection Type
* @param collectionClass 泛型的Collection
* @param elementClasses 元素类
* @return JavaType Java类型
* @since 1.0
*/
public static JavaType getCollectionType(Class<?> collectionClass, Class<?>... elementClasses) {
return mapper.getTypeFactory().constructParametricType(collectionClass, elementClasses);
}
复制代码
复杂类型转换 复制代码
ObjectMapper objectMapper = new ObjectMapper();
// 排除json字符串中实体类没有的字段
objectMapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
PledgeCertificate pledgeCertificate;
Pledge pledge = new Pledge();
try {
pledgeCertificate = objectMapper.readValue(requestBody, PledgeCertificate.class);
pledge = objectMapper.readValue(requestBody, Pledge.class);
   Map<String, Object> map = objectMapper.readValue(requestBody, Map.class);
String writeValueAsString = objectMapper.writeValueAsString(map.get("obligee"));
JavaType javaType = objectMapper.getTypeFactory().constructParametricType(List.class, Obligee.class);
List<Obligee> obligee = objectMapper.readValue(writeValueAsString,javaType);
}catch (IOException e) {
return “转换错误”;
} 数据格式:(实体类没有obligee字段,先排除)
{
“certificate”:"豫(2016)郑州市不动产权第0026369号",
“debtEnd”: "yyyy-mm-dd",
“debtStart”: "yyyy-mm-dd",
“pledgeType”: "2",
“maxDebtAmount”:88,
“registType”:"0201",
“obligee” :[{
"obligeeType":"1","name":张三","certType":"1","certNo":"4114211..."},{
"obligeeType":"1","name":"李四","certType":"1","certNo":"4114211..."}]
}
复制代码 { “certificate”:"豫(2016)郑州市不动产权第0026369号", “debtEnd”: "yyyy-mm-dd", “debtStart”: "yyyy-mm-dd", “pledgeType”: "2", “maxDebtAmount”:88, “registType”:"0201", “obligee” :[{ "obligeeType":"1","name":张三","certType":"1","certNo":"4114211..."},{ "obligeeType":"1","name":"李四","certType":"1","certNo":"4114211..."}] } 既然我已经踏上这条道路,那么,任何东西都不应妨碍我沿着这条路走下去!!!!!!!!!! !!! ! !! ! 个人公众号《后端技术开发之路》,欢迎您关注!
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); 方法二: String jsonString="[{'id':'1'},{'id':'2'}]";
ObjectMapper mapper = new ObjectMapper();
List<Bean> beanList = mapper.readValue(jsonString, new TypeReference<List<Bean>>() {});

Jackson objectMapper.readValue 方法 详解的更多相关文章

  1. session的使用方法详解

    session的使用方法详解 Session是什么呢?简单来说就是服务器给客户端的一个编号.当一台WWW服务器运行时,可能有若干个用户浏览正在运正在这台服务器上的网站.当每个用户首次与这台WWW服务器 ...

  2. Kooboo CMS - Html.FrontHtml[Helper.cs] 各个方法详解

    下面罗列了方法详解,每一个方法一篇文章. Kooboo CMS - @Html.FrontHtml().HtmlTitle() 详解 Kooboo CMS - Html.FrontHtml.Posit ...

  3. HTTP请求方法详解

    HTTP请求方法详解 请求方法:指定了客户端想对指定的资源/服务器作何种操作 下面我们介绍HTTP/1.1中可用的请求方法: [GET:获取资源]     GET方法用来请求已被URI识别的资源.指定 ...

  4. ecshop后台增加|添加商店设置选项和使用方法详解

    有时候我们想在Ecshop后台做个设置.radio.checkbox 等等来控制页面的显示,看看Ecshop的设计,用到了shop_config这个商店设置功能 Ecshop后台增加|添加商店设置选项 ...

  5. (转)Spring JdbcTemplate 方法详解

    Spring JdbcTemplate方法详解 文章来源:http://blog.csdn.net/dyllove98/article/details/7772463 JdbcTemplate主要提供 ...

  6. C++调用JAVA方法详解

    C++调用JAVA方法详解          博客分类: 本文主要参考http://tech.ccidnet.com/art/1081/20050413/237901_1.html 上的文章. C++ ...

  7. windows.open()、close()方法详解

    windows.open()方法详解:         window.open(URL,name,features,replace)用于载入指定的URL到新的或已存在的窗口中,并返回代表新窗口的Win ...

  8. CURL使用方法详解

    php采集神器CURL使用方法详解 作者:佚名  更新时间:2016-10-21   对于做过数据采集的人来说,cURL一定不会陌生.虽然在PHP中有file_get_contents函数可以获取远程 ...

  9. JAVA 注解的几大作用及使用方法详解

    JAVA 注解的几大作用及使用方法详解 (2013-01-22 15:13:04) 转载▼ 标签: java 注解 杂谈 分类: Java java 注解,从名字上看是注释,解释.但功能却不仅仅是注释 ...

  10. python MethodType方法详解和使用

    python 中MethodType方法详解和使用 废话不多说,直接上代码 #!/usr/bin/python # -*-coding:utf-8-*- from types import Metho ...

随机推荐

  1. C#设计模式03——简单工厂的写法

    什么是C#简单工厂? C#简单工厂是一种创建对象的设计模式,它定义一个工厂类来创建指定类型的对象,而不是在客户端代码中直接创建对象.简单工厂模式通常使用静态方法来生成对象,并且这些静态方法通常被称为工 ...

  2. windows10测试时如何构造大图片(如超过8M+的图片)

    1.原图片(大小40k) 2. 选怎一个容量大的文件如视频文件8M+ 3.使用copy命令进行扩容(cmd命令行操作): copy test01.jpg /b + 8M.MP4 test01_8M.j ...

  3. channel 是怎么走上死锁这条路的

    本篇文章接着 hello world 的并发实现一文介绍 Go 的 channel 类型,同时进一步介绍 channel 的几种死锁情况,这些都是代码中很容易遇到的,要重点摘出来讲,防止一不留神程序就 ...

  4. Python 学习笔记: 从变量到装饰器

    从变量开始 python 中全局变量在函数作用域内只能读,不能"写".如果要在函数作用域内实现修改全局变量值操作,需要使用关键字 global 显示指明该变量是全局变量. 但是,在 ...

  5. Linux进阶命令-grep

    Linux进阶命令----grep 目录 Linux进阶命令----grep grep 命令介绍 grep命令格式 常用选项 模式部分 匹配字符: 匹配次数: 位置锚定: grep 命令介绍 Linu ...

  6. 【C/C++】函数入参检查

    // 统计变参数量 #define CALC_VA_COUNT(arg...) \ ({ \ int count = 0; \ int insideQuotes = 0; \ const char * ...

  7. Laravel - Could not open input file: artisan 的解决方法

    cd 到 laravel的目录中执行 就可以了

  8. 多种数据库获取最近一天记录的SQL整理

    多种数据库获取最近一天记录的SQL整理 背景 纯粹当笔记. 数据库种类太多,记不住,每次都需要现查,效率实在是太低了 将获取最近一天记录的SQL整理好 方便后续直接his用 简单总结 Oracle + ...

  9. [转帖]linux中的set -e 与set -o pipefail

    https://www.cnblogs.com/xingmuxin/p/8431970.html 1.set -e "Exit immediately if a simple command ...

  10. rclone 的下载地址-官方网站

    Downloads Rclone is single executable (rclone, or rclone.exe on Windows) that you can simply downloa ...