Java前后端的JSON傳輸方式(前后端JSON格式轉(zhuǎn)換)
JSON 數(shù)據(jù)簡(jiǎn)介
1、什么是 JSON 數(shù)據(jù)
JSON(JavaScript Object Notation) 是一種輕量級(jí)的數(shù)據(jù)交換格式:key:value
格式。
JSON 采用完全獨(dú)立于語言的文本格式,這些特性使 JSON 成為理想的數(shù)據(jù)交換語言。易于人閱讀和編寫,同時(shí)也易于機(jī)器解析和生成。
2、JSON 字符串
JSON 字符串是一種 JSON 格式的 string 字符串,也就是 JSON 字符串也是 string 類型,只是這種 string 是有格式的,也就是類似 map 的格式【key:value】。
- JSON 字符串的鍵必須是字符串(也可以存數(shù)值,但是數(shù)值存進(jìn)去,取出來還是 String);
- JSON 字符串的值可以是:數(shù)字(整數(shù)或浮點(diǎn)數(shù)),字符串(在雙引號(hào)中),數(shù)組(在方括號(hào)中),對(duì)象(在花括號(hào)中),true/false/null。
3、后端 JSONObject 對(duì)象
JSONObject 是一種數(shù)據(jù)結(jié)構(gòu),可以理解為 JSON 格式的數(shù)據(jù)結(jié)構(gòu)(key-value 結(jié)構(gòu)),類似于 map,可以使用 put 方法給 JSONObject 對(duì)象添加元素。JSONObject 可以很方便的轉(zhuǎn)換成字符串,也可以很方便的把其他對(duì)象轉(zhuǎn)換成 JSONObject 對(duì)象。
(1)通過原生生成 JSONObject
JSONObject zhangsan = new JSONObject(); try { //添加 zhangsan.put("name", "張三"); zhangsan.put("age", 18.4); zhangsan.put("birthday", "1900-20-03"); zhangsan.put("majar", new String[] {"哈哈","嘿嘿"}); zhangsan.put("null", null); zhangsan.put("house", false); System.out.println(zhangsan.toString()); } catch (JSONException e) { e.printStackTrace(); }
(2)通過 hashMap 數(shù)據(jù)結(jié)構(gòu)生成
HashMap<String, Object> zhangsan = new HashMap<>(); zhangsan.put("name", "張三"); zhangsan.put("age", 18.4); zhangsan.put("birthday", "1900-20-03"); zhangsan.put("majar", new String[] {"哈哈","嘿嘿"}); zhangsan.put("null", null); zhangsan.put("house", false); System.out.println(new JSONObject(zhangsan).toString());
(3)通過 JavaBean 生成
Student student = new Student(); student.setId(1); student.setAge("20"); student.setName("張三"); // 生成 JSONObject System.out.println(JSON.toJSON(student));
(4)JSON 字符串與 JSONObject 轉(zhuǎn)換
String studentString = "{\"id\":1,\"age\":2,\"name\":\"zhang\"}"; //JSON字符串轉(zhuǎn)換成 JSONObject JSONObject jsonObject1 = JSONObject.parseObject(stuString); System.out.println(jsonObject1);
4、前端 JSON 字符串和 Javascript 對(duì)象對(duì)比
5、基礎(chǔ)結(jié)構(gòu)
JSON 的兩種結(jié)構(gòu):
(1)“名稱/值”對(duì)的集合(A collection of name/value pairs)。不同的語言中,它被理解為對(duì)象(object),記錄(record),結(jié)構(gòu)(struct),字典(dictionary),哈希表(hash table),有鍵列表(keyed list),或者關(guān)聯(lián)數(shù)組 (associative array)。
{ "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" }
(2)值的有序列表(An ordered list of values)。在大部分語言中,它被理解為數(shù)組(array)。
{ "people": [ { "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" }, { "firstName": "Jason", "lastName":"Hunter", "email": "bbbb"}, { "firstName": "Elliotte", "lastName":"Harold", "email": "cccc" } ]}
5、JSON 格式應(yīng)用
(1)將 JSON 數(shù)據(jù)賦值給變量
例如,可以創(chuàng)建一個(gè)新的 Javascript 變量,然后將 JSON 格式的數(shù)據(jù)字符串直接賦值給它:
var people = { "programmers": [ { "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" }, { "firstName": "Jason", "lastName":"Hunter", "email": "bbbb" }, { "firstName": "Elliotte", "lastName":"Harold", "email": "cccc" } ], "authors": [ { "firstName": "Isaac", "lastName": "Asimov", "genre": "science fiction" }, { "firstName": "Tad", "lastName": "Williams", "genre": "fantasy" }, { "firstName": "Frank", "lastName": "Peretti", "genre": "christian fiction" } ], "musicians": [ { "firstName": "Eric", "lastName": "Clapton", "instrument": "guitar" }, { "firstName": "Sergei", "lastName": "Rachmaninoff", "instrument": "piano" } ] }
(2)訪問數(shù)據(jù)
將上述這個(gè)數(shù)組放進(jìn) Javascript 變量之后,就可以很輕松地訪問它。實(shí)際上,只需用點(diǎn)號(hào)表示法來表示訪問數(shù)組元素。所以,要想訪問 programmers 列表的第一個(gè)條目的姓氏,只需在 JavaScript 中使用下面這樣的
代碼:
people.programmers[0].lastName;
(3)修改 JSON 數(shù)據(jù)
正如可以用點(diǎn)號(hào)和括號(hào)訪問數(shù)據(jù),也可以按照同樣的方式輕松地修改數(shù)據(jù)
people.musicians[1].lastName = "Rachmaninov";
(4)轉(zhuǎn)換字符串
可以將任何 JSONObject 和 Javascript 對(duì)象轉(zhuǎn)換為 JSON 文本,也可以進(jìn)行逆轉(zhuǎn)換。
一、后端將 Java 對(duì)象、JSONObject 轉(zhuǎn)換為 JSON 字符串格式
1、Jackson 類
(1)maven 引入依賴
<dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.9.9</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-core</artifactId> <version>2.9.9</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-annotations</artifactId> <version>2.9.9</version> </dependency>
(2)類庫函數(shù)使用
@RequestMapping(value="/returnJson") //@ResponseBody注解將JSON數(shù)據(jù)寫入響應(yīng)流中返回到前端 @ResponseBody public String returnJson(){ ObjectMapper objectMapper=new ObjectMapper(); Student student=new Student(); //writeValueAsString()函數(shù)將對(duì)象轉(zhuǎn)換為JSON字符串 return objectMapper.writeValueAsString(student); }
2、FastJson 類庫
(1)maven引入依賴
<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.4</version> </dependency>
(2)類庫函數(shù)使用
// 將 JSON 字符串反序列化成 JavaBean public static final Object parse(String text); // 將 JSON 字符串反序列化成 JSONObject public static final JSONObject parseObject(String text); // 將 JSON 字符串反序列化成 JavaBean 或 JSONObject public static final <T> T parseObject(String text, Class<T> clazz); // 將 JSON 字符串反序列化成JSONObject 的數(shù)組 public static final JSONArray parseArray(String text); // 將 JSON 字符串反序列化成 JavaBean 的數(shù)組 public static final <T> List<T> parseArray(String text, Class<T> clazz); // 將 Java 對(duì)象序列化為JSON 字符串 public static final String toJSONString(Object object); // 將 Java 對(duì)象序列化為帶格式的 JSON 字符串 public static final String toJSONString(Object object, boolean prettyFormat); //將 JavaBean 轉(zhuǎn)換為 JSONObject 或者 JSONArray。 public static final Object toJSON(Object javaObject);
parse() 及 parseObject() 進(jìn)行反序列化時(shí)的細(xì)節(jié)區(qū)別在于:parse() 會(huì)識(shí)別并調(diào)用目標(biāo)類的 setter 方法;parseObject() 由于要將返回值轉(zhuǎn)化為 JSONObject,多執(zhí)行了 JSON.toJSON(obj),也就是將 JavaBean 轉(zhuǎn)換成 JSONObject,所以在處理過程中會(huì)調(diào)用反序列化目標(biāo)類的 getter 方法來將參數(shù)賦值給 JSONObject。
3、使用 @RestController 注解
@RestController 是 @ResponseBody 和 @Controller 的組合注解。
- 1)@Controller 是用來響應(yīng)頁面的,如果是 string 類型的方法,則 springmvc 會(huì)跳轉(zhuǎn)到相應(yīng)的頁面(視圖)。
- 2)@ResponseBody 是用來響應(yīng)數(shù)據(jù)的,如果是對(duì)象類型或者 Map 類型的方法,則 springmvc 會(huì)將結(jié)果對(duì)象轉(zhuǎn)成 json 格式輸出給前端。(將 controller 的方法返回的對(duì)象通過適當(dāng)?shù)霓D(zhuǎn)換器轉(zhuǎn)換為指定的格式之后,寫入到 response 對(duì)象的 body 區(qū))
- 3)@RestController 注解會(huì)使 springmvc 將返回的對(duì)象或者 Map自 動(dòng)轉(zhuǎn) json 返回給前端(底層默認(rèn)是使用jsckson來實(shí)現(xiàn)數(shù)據(jù)格式轉(zhuǎn)換的)。
@RequestMapping(value="/returnJson") @ResponseBody public Student returnJson(){ Student student=new Student(); student.setName("林俊杰"); student.setBirth(new Date(1996-03-15)); student.setPassword("123456"); String[] lan= {"Java","Python"}; student.setLanguage(lan); return student; }
二、前端 Javascript 對(duì)象與 JSON 字符串格式的轉(zhuǎn)換
1、使用 JSON 庫
(1)Javascript 對(duì)象和 json 字符串轉(zhuǎn)換
var jsonVar = {key: value} //將JS對(duì)象轉(zhuǎn)換為JSON字符串 var jsonString = JSON.stringify(jsonVar) //將JSON字符串轉(zhuǎn)換為JSON對(duì)象 var jsonObject = JSON.parse(jsonString)
(2)Javascript 數(shù)組和 json 字符串轉(zhuǎn)換
var jsonVar = [value1,..,value] //將JS數(shù)組轉(zhuǎn)換為JSON字符串 var jsonString = JSON.stringify(jsonVar) //將JSON字符串轉(zhuǎn)換為數(shù)組對(duì)象 var jsonObject = JSON.parse(jsonString)
2、Javascript 自帶方法
Javascript 自帶的 eval ()函數(shù)能夠?qū)?json 數(shù)據(jù)轉(zhuǎn)換成 Javascript 對(duì)象。
var json = '{"name":"James"}'; var obj = eval( '(' + json + ')' ); //注意需要在json字符外包裹一對(duì)小括號(hào) alert( obj.name );
3、jQuery 的自帶方法
jQuery 中可以使用 $.parseJSON(json) 來將 json 轉(zhuǎn)換為 Javascript 對(duì)象。
var json = '{"name":"James"}'; var obj = $.parseJSON(json); alert( obj.name );
4、使用 jquery.json 插件
該插件提供了 4 個(gè)函數(shù),用于解析和反解析 json,具體如下:
- (1)toJSON:將 Javascript 的 object、number、string 或 array 轉(zhuǎn)換成 JSON 數(shù)據(jù)。
- (2)evalJSON:把 JSON 格式數(shù)據(jù)轉(zhuǎn)換成 Javascript 對(duì)象,速度很快,不過這點(diǎn)速度微不足道(作者自己說的)。
- (3)secureEvalJSON:把 JSON 轉(zhuǎn)換成 Javascript 對(duì)象,但是轉(zhuǎn)換之前會(huì)檢查被轉(zhuǎn)換的數(shù)據(jù)是否是 JSON 格式的。
- (4)quoteString:在字符串兩端添加引號(hào),并智能轉(zhuǎn)義(跳過)任何引號(hào),反斜杠,或控制字符。
- (注意:需要和 jQuery 核心庫結(jié)合使用)
var obj = {"plugin":"jquery-json","version":2.4}; //json = '{"plugin":"jquery-json","version":2.4}' var json = $.toJSON( obj ); // 得到name值為:"jquery-json" var name = $.evalJSON( json ).plugin; // 得到version值為:2.4 var version = $.evalJSON( json ).version;
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java數(shù)據(jù)結(jié)構(gòu) 遞歸之迷宮回溯案例講解
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)遞歸之迷宮回溯案例講解,本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08springboot application.properties 文件注入數(shù)組方式
這篇文章主要介紹了springboot application.properties 文件注入數(shù)組方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11Mybatis如何實(shí)現(xiàn)InsertOrUpdate功能
這篇文章主要介紹了Mybatis如何實(shí)現(xiàn)InsertOrUpdate功能,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05Java實(shí)現(xiàn)將漢字轉(zhuǎn)化為漢語拼音的方法
這篇文章主要介紹了Java實(shí)現(xiàn)將漢字轉(zhuǎn)化為漢語拼音的方法,實(shí)例演示了Java引用pinyin4j庫實(shí)現(xiàn)漢子轉(zhuǎn)化成拼音的使用技巧,需要的朋友可以參考下2015-12-12關(guān)于log4j漏洞修復(fù)解決方案及源碼編譯
Log4j?是Apache為Java提供的日志管理工具。他與System.out.println()的作用相似,用來跟蹤、調(diào)試、維護(hù)程序。這篇文章主要介紹了關(guān)于log4j漏洞修復(fù)解決方案及源碼編譯,需要的朋友可以參考下2021-12-12詳解Java的Hibernate框架中的搜索工具的運(yùn)用
這篇文章主要介紹了詳解Java的Hibernate框架中的搜索工具的運(yùn)用,Hibernate是Java的SSH三大web開發(fā)框架之一,需要的朋友可以參考下2015-11-11Java實(shí)現(xiàn)紀(jì)元秒和本地日期時(shí)間互換的方法【經(jīng)典實(shí)例】
這篇文章主要介紹了Java實(shí)現(xiàn)紀(jì)元秒和本地日期時(shí)間互換的方法,結(jié)合具體實(shí)例形式分析了Java日期時(shí)間相關(guān)操作技巧,需要的朋友可以參考下2017-04-04SpringBoot結(jié)合Redis配置工具類實(shí)現(xiàn)動(dòng)態(tài)切換庫
本文主要介紹了SpringBoot結(jié)合Redis配置工具類實(shí)現(xiàn)動(dòng)態(tài)切換庫,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08SpringMVC接收前臺(tái)傳遞過來的值的實(shí)例
下面小編就為大家分享一篇SpringMVC接收前臺(tái)傳遞過來的值的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-03-03