Json格式在后台服务中的重要性就不多说了,直入正题。
首先引入pom文件,这里使用的是1.2.83版本

1         <dependency>
2 <groupId>com.alibaba</groupId>
3 <artifactId>fastjson</artifactId>
4 <version>1.2.83</version>
5 </dependency>

接着我们尝试验证两种场景

1、Model对象转Json字符串

2、Json字符串转Model对象

在验证之前我们需要先编写一个model类,这个model类的字段我们可以使用fastJson中的注解@JSONField来修饰,并添加name值
这个注解的字段是,将该model类的字段和对应的json对象的key相对应起来。(防盗连接:本文首发自http://www.cnblogs.com/jilodream/ )
当然你也可以不添加该注解,这样就相当于使用了字段名称本身与json对象的key建立映射。
为了尽可能的展示各种场景,我在下边的model 示例中,使用了好几种场景
1、注解的name值与字段值相同
2、注解的name值与字段值不同
3、不设置注解
4、作用在复杂引用类型上
5、作用在基本类型上
7、作用在容器上

如图

 1 @Data
2 public class ProjectModel {
3 @JSONField(name = "projectName")
4 private String projectName;
5 @JSONField(name = "projectId")
6 private int id;
7 private List<String> userIdList;
8 @JSONField(name = "userBeanList")
9 private List<User> userList;
10 @JSONField(name = "adminUser")
11 private User adminUser;
12
13 @Data
14 public static class User {
15 @JSONField(name = "user-id")
16 private String userId;
17 private String user_Name;
18 }
19 }

接下来我们开始验证:

场景一、Model对象转Json字符串

 1     @PostConstruct
2 public void handleConvertJson() {
3 ProjectModel projectModel= createProjectModel();
4 String projectJson = JSON.toJSONString(projectModel);
5 System.out.println(projectJson);
6 }
7
8
9 private ProjectModel createProjectModel() {
10 ProjectModel projectModel = new ProjectModel();
11 projectModel.setId(999);
12 projectModel.setProjectName("p-1");
13 List<String> userIdList = new ArrayList<>();
14 userIdList.add("3");
15 userIdList.add("2");
16 userIdList.add("1");
17 projectModel.setUserIdList(userIdList);
18
19 ProjectModel.User adminUser=new ProjectModel.User();
20 adminUser.setUser_Name("admin");
21 adminUser.setUserId("0");
22 projectModel.setAdminUser(adminUser);
23
24 List<ProjectModel.User> userList = new ArrayList<>();
25 ProjectModel.User user3 = new ProjectModel.User();
26 user3.setUserId("3");
27 user3.setUser_Name("name3");
28 userList.add(user3);
29 ProjectModel.User user2 = new ProjectModel.User();
30 user2.setUserId("2");
31 user2.setUser_Name("name2");
32 userList.add(user2);
33 projectModel.setUserList(userList);
34 return projectModel;
35 }

执行结果格式化后如下

 1 {
2 "adminUser": {
3 "user-id": "0",
4 "user_Name": "admin"
5 },
6 "projectId": 999,
7 "projectName": "p-1",
8 "userBeanList": [
9 {
10 "user-id": "3",
11 "user_Name": "name3"
12 },
13 {
14 "user-id": "2",
15 "user_Name": "name2"
16 }
17 ],
18 "userIdList": [
19 "3",
20 "2",
21 "1"
22 ]
23 }

注意看,(防盗连接:本文首发自http://www.cnblogs.com/jilodream/ )如果model类字段设置了JSONField注解的话,则优先级最高,如果未设置该注解的话,则按照model类中字段的名称进行设置。而基本类型、复杂类型、复杂类型容器等场景均支持。

场景二、Model对象转Json字符串

新增代码如下

 1     @PostConstruct
2 public void handleJson2() {
3 String newSourceJson="{\"projectId\":999,\"projectName\":\"p-1\"," +
4 "\"userBeanList\":[{\"userId\":\"3\",\"user_Name\":\"name3\"},{\"user-id\":\"2\"," +
5 "\"user_Name\":\"name2\"}],\"userIdList\":[\"3\",\"2\",\"1\"]}";
6 ProjectModel newProject = JSONObject.parseObject(newSourceJson,
7 ProjectModel.class);
8 String newProjectJson = JSON.toJSONString(newProject);
9 System.out.println(newSourceJson);
10 System.out.println(newProjectJson);
11 }

Json串我们使用场景1的输出,但是稍作修改:删掉adminUser,同时注意userBeanList容器中的元素,两个id的key不一样,一个叫做userId(类字段名),一个叫做user-id(JSONField的name值)。然后再将对象转为Json串,用这两个Json串进行比较:

经过转换后,userId字段消失了,这是由于null值不会被序列化出来的缘故。也从侧面证明了反序列化时,如果@JSONField存在的话,必须要与@JSONField值保持一致,否则字段值不会写入。如图:

另外我们补充一个特殊情况情况,Model对象的字段为null转Json串时,如何保留null值:(防盗连接:本文首发自http://www.cnblogs.com/jilodream/ )

注意第8行的转换增加了参数SerializerFeature.WriteMapNullValue

 1     @PostConstruct
2 public void handleJson3() {
3 String newSourceJson="{\"projectId\":999,\"projectName\":\"p-1\"," +
4 "\"userBeanList\":[{\"userId\":\"3\",\"user_Name\":\"name3\"},{\"user-id\":\"2\"," +
5 "\"user_Name\":\"name2\"}],\"userIdList\":[\"3\",\"2\",\"1\"]}";
6 ProjectModel newProject = JSONObject.parseObject(newSourceJson,
7 ProjectModel.class);
8 String newProjectJson=JSON.toJSONString(newProject, SerializerFeature.WriteMapNullValue);
9 System.out.println(newSourceJson);
10 System.out.println(newProjectJson);
11 }

效果如下,生成的json串会保留null字段

Springboot 通过FastJson实现bean对象和Json字符串互转的更多相关文章

  1. Json对象与Json字符串互转(转载)

    一.jQuery插件支持的转换方式 1 $.paseJSON(jsonstr);//将json字符串转换为json对象 二.浏览器支持的转换方式(Firefox,Chrome,Opera,Safair ...

  2. Json对象与Json字符串互转(4种转换方式)

    Json字符与Json对象的相互转换方式有很多,接下来将为大家一一介绍下,感兴趣的朋友可以参考下哈,希望可以帮助到你 1>jQuery插件支持的转换方式: 复制代码代码如下: $.parseJS ...

  3. Json对象与Json字符串互转

    1>jQuery插件支持的转换方式: 复制代码 代码如下: $.parseJSON( jsonstr ); //jQuery.parseJSON(jsonstr),可以将json字符串转换成js ...

  4. Json对象与Json字符串互转(4种转换方式)(转)

    1>jQuery插件支持的转换方式: $.parseJSON( jsonstr ); //jQuery.parseJSON(jsonstr),可以将json字符串转换成json对象  2> ...

  5. json对象与json字符串互转方法

    jQuery插件支持的转换方式: 复制代码 代码如下: $.parseJSON( jsonstr ); //jQuery.parseJSON(jsonstr),可以将json字符串转换成json对象 ...

  6. 前端Json对象与Json字符串互转(4种转换方式)

    1>jQuery插件支持的转换方式: $.parseJSON( jsonstr ); //jQuery.parseJSON(jsonstr),可以将json字符串转换成json对象 2>浏 ...

  7. Json对象与Json字符串互转(4种转换方式) jquery 以及 js 的方式

    http://blog.csdn.net/zero_295813128/article/details/51545467

  8. fastjson: json对象,json对象数组,javabean对象,json字符串之间的相互转化

    fastjson: json对象,json对象数组,javabean对象,json字符串之间的相互转化 在开发过程中,经常需要和前端交互数据,数据交互的格式都是JSON,在此过程中免不了json字符串 ...

  9. java对象与Json字符串之间的转化(fastjson)

    1. 首先引入jar包 在pom.xml文件里加入下面依赖: <dependency> <groupId>com.alibaba</groupId> <art ...

随机推荐

  1. 【ASP.NET Core】配置应用程序地址的N多种方法

    下面又到了老周误人子弟的时间,今天要误大伙的话题是:找找有多少种方法可以设置 ASP.NET Core 应用的地址,即 URL. 精彩马上开始! 1.UseUrls 方法 这是一个扩展方法,参数是可变 ...

  2. Web自动化定位方法以及常用便捷操作

    很遗憾现在才开始给大家逐步分享自动化教程,原本计划着将现有的接口以及app.pc网页端进行自动化处理后再逐步给大家好好分享一下,由于当前实在没必要自动化操作了,所以临时用脑海中的知识再为大家继续更一篇 ...

  3. php为图片添加水印

    <?php /** * 图片加水印(适用于png/jpg/gif格式) * * @author flynetcn * * @param $srcImg 原图片 * @param $waterIm ...

  4. JDBC、ORM、JPA、Spring Data JPA,傻傻分不清楚?一文带你厘清个中曲直,给你个选择SpringDataJPA的理由!

    序言 Spring Data JPA作为Spring Data中对于关系型数据库支持的一种框架技术,属于ORM的一种,通过得当的使用,可以大大简化开发过程中对于数据操作的复杂度. 本文档隶属于< ...

  5. vscode常用插件快捷键

    俗话说,工欲善其事必先利其器,我们码农的器是什么尼?没错,就是我们亲爱的IDE,前端开发者最爱的编辑器应该是vscode了吧.但是我们要怎么去锋利它尼?不外乎就是熟悉它的使用方法.快捷键以及第三方的插 ...

  6. RPA应用场景-信用卡交易争议后续流程

    RPA应用场景-信用卡交易争议后续流程 场景概述 信用卡交易争议后续流程 所涉系统名称 客服系统,邮件 人工操作(时间/次) 4小时 所涉人工数量20操作频率 不定时 场景流程 1.RPA自动接收客户 ...

  7. 使用Navicat创建存储过程(顺带插入百万级数据量)

    一.建表 DROP TABLE IF EXISTS `test_user`; CREATE TABLE `test_user` ( `id` bigint(20) PRIMARY key not nu ...

  8. 机器学习基础:用 Lasso 做特征选择

    大家入门机器学习第一个接触的模型应该是简单线性回归,但是在学Lasso时往往一带而过.其实 Lasso 回归也是机器学习模型中的常青树,在工业界应用十分广泛.在很多项目,尤其是特征选择中都会见到他的影 ...

  9. Zabbix 5.0:通过LLD方式自动化监控阿里云RDS

    Blog:博客园 个人 之前做了RDS监控,由于 RDS 实例梳理增多,手动添加的方式已经不够效率,故改为LLD(Low-level discovery)方式做监控. 什么是LLD LLD(Low-l ...

  10. 30m精度土壤类型、土壤质地、土壤有机质、土壤PH、土壤氮磷钾

    ​数据下载链接:数据下载链接 引言 全国土壤类型.质地.养分及变化等信息产品分为土壤类型数据.土壤质地数据.土壤养分数据及土壤变化数据等.该类产品是基于野外调查和实地采样,结合历史数据,建立全国土壤类 ...