Springboot?通過FastJson實(shí)現(xiàn)bean對(duì)象和Json字符串互轉(zhuǎn)問題
Json格式在后臺(tái)服務(wù)中的重要性就不多說了,直入正題。
首先引入pom文件,這里使用的是1.2.83版本
<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.83</version> </dependency>
接著我們嘗試驗(yàn)證兩種場(chǎng)景
1、Model對(duì)象轉(zhuǎn)Json字符串
2、Json字符串轉(zhuǎn)Model對(duì)象
在驗(yàn)證之前我們需要先編寫一個(gè)model類,這個(gè)model類的字段我們可以使用fastJson中的注解@JSONField來修飾,并添加name值。
這個(gè)注解的作用,將該model類的字段和對(duì)應(yīng)的json對(duì)象的key相對(duì)應(yīng)起來。(防盜連接:本文首發(fā)自 )
當(dāng)然你也可以不添加該注解,這樣就相當(dāng)于使用了字段名稱本身與json對(duì)象的key建立映射。
為了盡可能的展示各種場(chǎng)景,我在下邊的model 示例中,使用了好幾種場(chǎng)景
1、注解的name值與字段值相同
2、注解的name值與字段值不同
3、不設(shè)置注解
4、作用在復(fù)雜引用類型上
5、作用在基本類型上
7、作用在容器上
如圖
@Data public class ProjectModel { @JSONField(name = "projectName") private String projectName; @JSONField(name = "projectId") private int id; private List<String> userIdList; @JSONField(name = "userBeanList") private List<User> userList; @JSONField(name = "adminUser") private User adminUser; @Data public static class User { @JSONField(name = "user-id") private String userId; private String user_Name; } }
接下來我們開始驗(yàn)證:
場(chǎng)景一、Model對(duì)象轉(zhuǎn)Json字符串
@PostConstruct public void handleConvertJson() { ProjectModel projectModel= createProjectModel(); String projectJson = JSON.toJSONString(projectModel); System.out.println(projectJson); } private ProjectModel createProjectModel() { ProjectModel projectModel = new ProjectModel(); projectModel.setId(999); projectModel.setProjectName("p-1"); List<String> userIdList = new ArrayList<>(); userIdList.add("3"); userIdList.add("2"); userIdList.add("1"); projectModel.setUserIdList(userIdList); ProjectModel.User adminUser=new ProjectModel.User(); adminUser.setUser_Name("admin"); adminUser.setUserId("0"); projectModel.setAdminUser(adminUser); List<ProjectModel.User> userList = new ArrayList<>(); ProjectModel.User user3 = new ProjectModel.User(); user3.setUserId("3"); user3.setUser_Name("name3"); userList.add(user3); ProjectModel.User user2 = new ProjectModel.User(); user2.setUserId("2"); user2.setUser_Name("name2"); userList.add(user2); projectModel.setUserList(userList); return projectModel; }
執(zhí)行結(jié)果格式化后如下
{
"adminUser": {
"user-id": "0",
"user_Name": "admin"
},
"projectId": 999,
"projectName": "p-1",
"userBeanList": [
{
"user-id": "3",
"user_Name": "name3"
},
{
"user-id": "2",
"user_Name": "name2"
}
],
"userIdList": [
"3",
"2",
"1"
]
}
注意看,(防盜連接:本文首發(fā)自)如果model類字段設(shè)置了JSONField注解的話,則優(yōu)先級(jí)最高,如果未設(shè)置該注解的話,則按照model類中字段的名稱進(jìn)行設(shè)置。而基本類型、復(fù)雜類型、復(fù)雜類型容器等場(chǎng)景均支持。
場(chǎng)景二、Model對(duì)象轉(zhuǎn)Json字符串
新增代碼如下:
@PostConstruct public void handleJson2() { String newSourceJson="{\"projectId\":999,\"projectName\":\"p-1\"," + "\"userBeanList\":[{\"userId\":\"3\",\"user_Name\":\"name3\"},{\"user-id\":\"2\"," + "\"user_Name\":\"name2\"}],\"userIdList\":[\"3\",\"2\",\"1\"]}"; ProjectModel newProject = JSONObject.parseObject(newSourceJson, ProjectModel.class); String newProjectJson = JSON.toJSONString(newProject); System.out.println(newSourceJson); System.out.println(newProjectJson); }
Json串我們使用場(chǎng)景1的輸出,但是稍作修改:刪掉adminUser,同時(shí)注意userBeanList容器中的元素,兩個(gè)id的key不一樣,一個(gè)叫做userId(類字段名),一個(gè)叫做user-id(JSONField的name值)。然后再將對(duì)象轉(zhuǎn)為Json串,用這兩個(gè)Json串進(jìn)行比較:
經(jīng)過轉(zhuǎn)換后,userId字段消失了,這是由于null值不會(huì)被序列化出來的緣故。也從側(cè)面證明了反序列化時(shí),如果@JSONField存在的話,必須要與@JSONField值保持一致,否則字段值不會(huì)寫入。如圖:
另外我們補(bǔ)充一個(gè)特殊情況情況,Model對(duì)象的字段為null轉(zhuǎn)Json串時(shí),如何保留null值:(防盜連接:本文首發(fā)自)
注意第8行的轉(zhuǎn)換增加了參數(shù)SerializerFeature.WriteMapNullValue
@PostConstruct public void handleJson3() { String newSourceJson="{\"projectId\":999,\"projectName\":\"p-1\"," + "\"userBeanList\":[{\"userId\":\"3\",\"user_Name\":\"name3\"},{\"user-id\":\"2\"," + "\"user_Name\":\"name2\"}],\"userIdList\":[\"3\",\"2\",\"1\"]}"; ProjectModel newProject = JSONObject.parseObject(newSourceJson, ProjectModel.class); String newProjectJson=JSON.toJSONString(newProject, SerializerFeature.WriteMapNullValue); System.out.println(newSourceJson); System.out.println(newProjectJson); }
效果如下,生成的json串會(huì)保留null字段
到此這篇關(guān)于Springboot通過FastJson實(shí)現(xiàn)bean對(duì)象和Json字符串互轉(zhuǎn)的文章就介紹到這了,更多相關(guān)SpringbootFastJson實(shí)現(xiàn)bean和Json互轉(zhuǎn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringCache緩存自定義配置的實(shí)現(xiàn)
本文主要介紹了SpringCache緩存自定義配置的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01MyBatis實(shí)現(xiàn)動(dòng)態(tài)查詢、模糊查詢功能
這篇文章主要介紹了MyBatis實(shí)現(xiàn)動(dòng)態(tài)查詢、模糊查詢功能,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-06-06Springboot整合ActiveMQ實(shí)現(xiàn)消息隊(duì)列的過程淺析
昨天仔細(xì)研究了activeMQ消息隊(duì)列,也遇到了些坑,下面這篇文章主要給大家介紹了關(guān)于SpringBoot整合ActiveMQ的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02簡(jiǎn)單了解Thymeleaf語(yǔ)法 數(shù)據(jù)延遲加載使用實(shí)例
這篇文章主要介紹了簡(jiǎn)單了解Thymeleaf語(yǔ)法 數(shù)據(jù)延遲加載使用實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2010-05-05