如何将一个Json序列化对象封装成为一个Pojo是实体类对象

public static void main(String[] args) {

        //创建ObjectMapper对象,这是一个可重复使用的对象
ObjectMapper mapper = new ObjectMapper();
String jsonString = "{\"name\":\"Mahesh\", \"age\":21}"; //map to json student
try {
//反序列化得到JSON对象,
// 从JSON对象使用readValue方法来获取,通过JSON字符串对象类型作为参数JSON字符串(json字符串,字符串类型)
Student student = mapper.readValue(jsonString, Student.class);
System.out.println(student.toString()); //设置JSON的格式[缩进、单\双引号....]
mapper.enable(SerializationFeature.INDENT_OUTPUT);
//使用writeValueAsString()方法来获取对象的JSON字符串表示。
jsonString = mapper.writeValueAsString(student);
System.out.println(jsonString);
} catch (Exception e) {
e.printStackTrace();
}
}

如何进行序列化与反序列化

 public static void main(String[] args) {
JacksonSer jacksonSer = new JacksonSer();
try {
Student student = new Student();
student.setAge(22);
student.setName("RenZetong"); //将Pojo对象序列化为Json
jacksonSer.writeJSON(student); //将Json反序列化为Pojo对象
Student student1 = jacksonSer.readJSON();
System.out.println(student1);
} catch (Exception e) {
e.printStackTrace();
}
} /**
* 序列化
*
* @param student
* @throws Exception
*/
private void writeJSON(Student student) throws Exception {
ObjectMapper mapper = new ObjectMapper();
//使用writeValue来将Json文件写入(Json文件,映射类)
mapper.writeValue(new File("./data/student.json"), student);
} /**
* 反序列化
*
* @return
* @throws Exception
*/
private Student readJSON() throws Exception {
ObjectMapper mapper = new ObjectMapper();
//从JSON对象使用readValue方法来获取,通过JSON字符串对象类型作为参数JSON字符串(json字符串,字符串类型)
Student student = mapper.readValue(new File("./data/student.json"), Student.class);
return student;
}

如何将数据进行绑定

 public static void main(String[] args) throws Exception {
ObjectMapper mapper = new ObjectMapper(); Map<String, Object> studentMap = new HashMap<>();
int[] marks = {1, 2, 3}; Student student = new Student();
student.setAge(10);
student.setName("Mahesh"); //Java Object 也就是实体类对象
studentMap.put("student", student);
//Java String 也就是键值对
studentMap.put("name", "Mahesh Kumar");
//Java Boolean
studentMap.put("verified", Boolean.FALSE);
//Array Type 数组类型
studentMap.put("marks", marks); //将map数据序列化为Json
//mapper.writeValue(new File("./data/students.json"), studentMap); //将复杂型Json通过readValue解析到Map集合中(Json文件,映射类型) 反序列化
studentMap = mapper.readValue(new File("./data/students.json"), Map.class); //反序列化集合中的Json数据
System.out.println(studentMap.get("student"));
System.out.println(studentMap.get("name"));
System.out.println(studentMap.get("verified"));
System.out.println(studentMap.get("marks")); //反序列化数组对象
List<Integer> list = (List<Integer>) studentMap.get("marks");
for (Integer integer : list) {
System.out.println(integer);
}
}

如何进行泛型数据绑定

public String method() throws IOException {
ObjectMapper mapper = new ObjectMapper();
User user = new User();
user.setId(1);
Pager<User> pager = new Pager<User>();
List<User> users = new ArrayList<User>();
users.add(user);
pager.setDatas(users);
String json = mapper.writeValueAsString(pager);
// 方式1
Pager<User> userPager1 = mapper.readValue(json, new TypeReference<Pager<User>>() {
});
// 方式2
Type[] types = new Type[1];
types[0] = User.class;
final ParameterizedTypeImpl type = ParameterizedTypeImpl.make(Pager.class, types, Pager.class.getDeclaringClass());
TypeReference typeReference = new TypeReference<Pager>() {
@Override
public Type getType() {
return type;
}
};
Pager<User> userPager2 = mapper.readValue(json, typeReference);
// 方式3
JavaType javaType = mapper.getTypeFactory().constructParametrizedType(Pager.class, Pager.class, User.class);
Pager<User> userPager3 = mapper.readValue(json, javaType);
// 方式4
JavaType javaType1 = mapper.getTypeFactory().constructParametricType(Pager.class, User.class);
Pager<User> userPager4 = mapper.readValue(json, javaType1);
// 方式5,新建另一个指定具体泛型T的参数的类
PagerAppoint userPager5 = mapper.readValue(json, PagerAppoint.class);
// 数组泛型的序列化和反序列化
String json1 = mapper.writeValueAsString(users);
JavaType javaType2 = mapper.getTypeFactory().constructParametricType(List.class, User.class);
List<User> users1 = mapper.readValue(json1, javaType2);
// HashMap
Map<String, User> map = new HashMap<String, User>(16);
map.put("test", user);
String json2 = mapper.writeValueAsString(map);
// 1
Map<String, User> users2 = mapper.readValue(json2, new TypeReference<Map<String, User>>() {
});
// 2
JavaType javaType3 = mapper.getTypeFactory().constructParametricType(HashMap.class, String.class, User.class);
Map<String, User> users3 = mapper.readValue(json2, javaType3); return "hello world";
}
}

如何使用Jackson树模型(将复杂Json手动映射到类型)

public static void main(String[] args) throws Exception {
ObjectMapper mapper = new ObjectMapper();
String jsonString = "{\"name\":\"Mahesh Kumar\", \"age\":21,\"verified\":false,\"marks\": [100,90,85]}"; //使用readTree来读取json数据
JsonNode rootNode = mapper.readTree(jsonString); //使用path获取节点
JsonNode nameNode = rootNode.path("name");
System.out.println("Name: " + nameNode.textValue()); JsonNode ageNode = rootNode.path("age");
System.out.println("Age: " + ageNode.intValue()); JsonNode verifiedNode = rootNode.path("verified");
System.out.println("Verified: " + verifiedNode.booleanValue()); JsonNode marksNode = rootNode.path("marks");
Iterator<JsonNode> iterator = marksNode.elements();
System.out.println("Marks:[");
for (JsonNode node : marksNode) {
System.out.println(node.intValue());
}
System.out.println("]");
}

读取json文件进行树遍历

public static void main(String[] args) throws Exception {
ObjectMapper mapper = new ObjectMapper(); JsonNode rootNode; //读取Json文件到JsonNode;
rootNode = mapper.readTree(new File("./data/students.json")); //使用树模型来读取Json文件并映射到Pojo对象
UserInfo userInfo = mapper.treeToValue(rootNode, UserInfo.class); System.out.println("Name: " + userInfo.getName());
}

使用Jackson进行流式处理

JacksonParse类用于读取Json,JacksonGenerator用于编写Json

public static void main(String[] args) throws Exception {
//writeJSON();
readJSON();
} //使用JsonGenerator写入JSON
public static JsonGenerator writeJSON() throws Exception {
JsonFactory jsonFactory = new JsonFactory();
//创建json输出路径以及字符编码
JsonGenerator jsonGenerator = jsonFactory.createGenerator(new File("./data/stu.json"), JsonEncoding.UTF8);
//{
jsonGenerator.writeStartObject();
jsonGenerator.writeStringField("name", "RenZetong");
jsonGenerator.writeNumberField("age", 22);
jsonGenerator.writeBooleanField("verified", false); //marks:[
jsonGenerator.writeFieldName("marks");
jsonGenerator.writeStartArray();
jsonGenerator.writeNumber(100);
jsonGenerator.writeNumber(90);
jsonGenerator.writeNumber(85);
jsonGenerator.writeEndArray();
//]
jsonGenerator.writeEndObject();
jsonGenerator.close();
//} return jsonGenerator;
//result student.json
//{
// "name":"Mahesh Kumar",
// "age":21,
// "verified":false,
// "marks":[100,90,85]
//}
} //使用JsonParser解析JSON字符串
public static void readJSON() throws Exception {
JsonFactory jsonFactory = new JsonFactory();
JsonParser jsonParser = jsonFactory.createParser(new File("./data/stu.json"));
//如果没有迭代到Json对象结束节点则一直循环
while (jsonParser.nextToken() != JsonToken.END_OBJECT) {
//获取当前节点名称
String fieldName = jsonParser.getCurrentName();
if ("name".equals(fieldName)) {
//如果没有剩余标记则停止迭代
jsonParser.nextToken();
//获取当前节点值
System.out.println(jsonParser.getText());
}
if ("age".equals(fieldName)) {
jsonParser.nextToken();
System.out.println(jsonParser.getNumberValue());
}
if ("verified".equals(fieldName)) {
jsonParser.nextToken();
System.out.println(jsonParser.getBooleanValue());
}
if ("marks".equals(fieldName)) {
jsonParser.nextToken();
//如果没有迭代到Json数组对象结束节点则一直循环
while (jsonParser.nextToken() != JsonToken.END_ARRAY) {
System.out.println(jsonParser.getNumberValue());
}
}
}
}

Jackson基本使用教程的更多相关文章

  1. 来自Jakob Jenkov的Jackson教程

    Jakob Jenkov是Java界的牛人. 下面是收集的与Jackson有关的教程: JSON: http://tutorials.jenkov.com/java-json/index.html J ...

  2. Jackson 教程演示样例

    查看原文教程:http://www.ibloger.net/article/275.html Json经常使用的类库例如以下 Jackson:http://jackson.codehaus.org/ ...

  3. 使用Jackson来实现Java对象与JSON的相互转换的教程

    一.入门Jackson中有个ObjectMapper类很是实用,用于Java对象与JSON的互换.1.JAVA对象转JSON[JSON序列化] 1 2 3 4 5 6 7 8 9 10 11 12 1 ...

  4. Jackson教程

    Jackson是一个简单基于Java应用库,Jackson可以轻松的将Java对象转换成json对象和xml文档,同样也可以将json.xml转换成Java对象.Jackson所依赖的jar包较少,简 ...

  5. Jackson 解析 JSON 详细教程

    点赞再看,动力无限. 微信搜「程序猿阿朗 」. 本文 Github.com/niumoo/JavaNotes 和 未读代码博客 已经收录,有很多知识点和系列文章. JSON 对于开发者并不陌生,如今的 ...

  6. [转]SSM框架——详细整合教程(Spring+SpringMVC+MyBatis)

    原文地址:http://blog.csdn.net/zhshulin/article/details/37956105#comments 使用SSM(Spring.SpringMVC和Mybatis) ...

  7. 【转】SSM框架——详细整合教程(Spring+SpringMVC+MyBatis)

    原文地址:http://blog.csdn.net/zhshulin/article/details/37956105 使用SSM(Spring.SpringMVC和Mybatis)已经有三个多月了, ...

  8. Spring MVC 教程,快速入门,深入分析

    http://elf8848.iteye.com/blog/875830/ Spring MVC 教程,快速入门,深入分析 博客分类: SPRING Spring MVC 教程快速入门  资源下载: ...

  9. Spring_MVC_教程_快速入门_深入分析

    Spring MVC 教程,快速入门,深入分析 博客分类: SPRING Spring MVC 教程快速入门  资源下载: Spring_MVC_教程_快速入门_深入分析V1.1.pdf Spring ...

  10. Jackson注解学习参考(转)

    转:http://wong-john.iteye.com/blog/1753402 以下内容摘录.翻译自https://github.com/FasterXML/jackson-annotations ...

随机推荐

  1. ShardingSphere系列(一)——ShardingSphere-JDBC初体验

    Apache ShardingSphere 是一套开源的分布式数据库解决方案组成的生态圈,它由 JDBC.Proxy 和 Sidecar(规划中)这 3 款既能够独立部署,又支持混合部署配合使用的产品 ...

  2. 关于softmax在CV多通道中的理解

    1.采用分类任务时,我们通常会采用逻辑回归算法,最关键的步骤就是将线性模型输出的实数域映射到[0, 1]表示概率分布的有效实数空间,其中Sigmoid函数刚好具有这样的功能.但是这通常只适用于二分类问 ...

  3. vuex 的modules 子模块总结

  4. manim边做边学--有向图

    有向图和上一篇介绍的无向图基本一样,唯一的区别在于有向图的边有方向性,它表示的是顶点之间的单向或依赖关系. 有向图G一般表示为:G=<V,E>.和无向图一样,V是顶点集合,E是边的集合. ...

  5. 用sdkman管理多个jdk切换

    前言 最近项目前后端进行升级,需要在jdk8和jdk17两个版本切换.最简单的是通过手动切换,但切换过程太繁琐,修改环境变量,达到切换目的.于是尝试其它解决方案,最终确实使用sdkman工具. sdk ...

  6. RocketMQ Streams拓扑构建与数据处理过程

    本文作者:倪泽,Apache RocketMQ committer.RSQLDB/RocketMQ Streams Maintainer 01 背景 RocketMQ Streams 1.1.0版本已 ...

  7. 基于QToolButton封装,解决Icon不能设置hover和press态的问题

    1 #pragma once 2 #include <QToolButton> 3 #include <QBoxLayout> 4 #include <QLabel> ...

  8. Windows系统DOS命令详解

    一. DOS 的历史 DOS(Disk Operating System),磁盘操作系统 1980 年,西雅图程序员蒂姆-帕特森,86-DOS 1981 年由微软公司购买并改进,更名为 MS-DOS ...

  9. Air780E软件指南:UDP应用示例

    一.UDP概述 UDP(用户数据报协议,UserDatagramProtocol)是一种无连接的.不可靠的传输层协议,主要用于实现网络中的快速通讯.以下是UDP通讯的主要特点: 1.1 无连接通讯: ...

  10. mysql 触发器阻止不合理数据插入

    今天看到有人问如何判断处理有不符合的数据阻止插入.比如这个数据只能在90天内存在一条,如果有了就拒绝插入. 当然大家都说用代码判断,判断一下90天内是否有数据,有就拒绝. 我这里说一个使用触发器的思路 ...