国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 開發 > Java > 正文

SpringMVC接收與響應json數據的幾種方式

2024-07-14 08:43:48
字體:
來源:轉載
供稿:網友

前言

前后端的數據交互,除了通過form表單進行提交外,也可以通過ajax向后端傳遞和接收json格式數據(這種方式可以實現請求數據和頁面分離)。本文將總結一下在Spring MVC中接收和響應json數據的幾種方式。

話不多說了,來一起看看詳細的介紹吧

準備步驟:

1.導入json相關框架的依賴(比如jackson)。

2.spring mvc的controller方法正常寫,如果需要響應json,增加@responsebody注解。

3.在接受json對應的輸入參數前,加上@RequestBody注解。

服務端接收json數據還原為java對象,稱為反序列化,反之,將java對象作為響應轉換為json數據發回給客戶端,稱為序列化。

注意:因為要使用ajax,所有一定要引入jQuery,切記!

jackson maven依賴:

  <!-- jackson依賴 -->  <dependency>   <groupId>com.fasterxml.jackson.core</groupId>   <artifactId>jackson-core</artifactId>   <version>2.7.0</version>  </dependency>  <dependency>   <groupId>com.fasterxml.jackson.core</groupId>   <artifactId>jackson-databind</artifactId>   <version>2.7.0</version>  </dependency>  <dependency>   <groupId>com.fasterxml.jackson.core</groupId>   <artifactId>jackson-annotations</artifactId>   <version>2.7.0</version>  </dependency>

一、以實體類接收

背景:當ajax傳遞的參數較多時,采用參數名匹配的方法不太方便。如果后臺有對應的實體類,這時可以選擇在客戶端將數據封裝為json格式傳遞給后臺,后臺用對應的實體類進行接收。

客戶端:

<button onclick="clickMe()">點我</button><script> function clickMe() {  $.ajax({   type : 'POST',   url : "acceptJsonByEntity",   contentType : "application/json;charset=utf-8",   // 如果想以json格式把數據提交到后臺的話,JSON.stringify()必須有,否則只會當做表單提交   data : JSON.stringify({    "bookId" : 1,    "author" : "Jack"   }),   // 期待返回的數據類型   dataType : "json",   success : function(data) {    var bookId = data.bookId;    var author = data.author;    alert("success:" + bookId+','+author);   },   error : function(data) {    alert("error" + data);   }  });</script>

@responseBody注解是將controller的方法返回的對象通過適當的轉換器轉換為指定的格式之后,寫入到response對象的body區,通常用來返回JSON數據或者是XML。

@RequestBody注解常用來處理content-type不是默認的application/x-www-form-urlcoded編碼的內容。一般情況下來說常用其來處理application/json類型。

Controller:

@Controllerpublic class PassJsonParam { @RequestMapping(value="acceptJsonByEntity",method = RequestMethod.POST) @ResponseBody public Book acceptJsonByEntity(@RequestBody Book book, HttpServletRequest request){  System.out.println("當前http請求方式為:"+request.getMethod());  System.out.println("bookId="+book.getBookId()+", author="+book.getAuthor());  return book; }}

控制臺輸出:當前http請求方式為:POST bookId=1, author=Jack

客戶端(彈窗):success:1,Jack

如果Controller中的所有方法都需要返回json格式數據,可以使用@RestController注解。
@RestController = @Controller + @ResponseBody

Controller(上面的Controller可以用下面的替換):

@RestControllerpublic class PassJsonParam { @RequestMapping(value="acceptJsonByEntity",method = RequestMethod.POST) public Book acceptJsonByEntity(@RequestBody Book book, HttpServletRequest request){  System.out.println("當前http請求方式為:"+request.getMethod());  System.out.println("bookId="+book.getBookId()+", author="+book.getAuthor());  return book; }}

注意:使用了@RestController注解后,Controller的方法無法再返回jsp頁面或者html,配置的視圖解析器也不會起作用。

二、以map方式接收

背景:前臺向后臺發送ajax請求并且攜帶很多參數,而后臺并沒有對應的實體類進行接收又該如何處理呢?最常見的就是表單,這里可以考慮使用map來解決。因為map的數據結構為key-value形式,所以我們可以遍歷搜索框表單,將表單的name作為map的key,表單的value作為map的value。

客戶端:

<form id="bookForm"> <input type="text" name="bookName" id="bookName"> <input type="text" name="author" id="author" > <button onclick="submitForm(event)">提交</button></form><script> function submitForm(event) {  //阻止form默認事件  event.preventDefault();  //得到搜索框數據  var map = new Map();  $("#bookForm input").each(function () {   var value = $(this).val();  //input 值   var name = $(this).attr('name');   map.set(name,value);  })  //Map轉為Json的方法  var obj= Object.create(null);  for (var [k,v] of map) {   obj[k] = v;  }  $.ajax({   type: 'POST',   contentType:'application/json',   url: "acceptJsonByMap",   data: JSON.stringify(obj),   dataType: 'json',   success: function (data) {    var bookName = data.bookName;    var author = data.author;    alert("bookName ="+bookName+"; author="+author);   },   error: function (data) {    alert("失敗啦");   }  }); }</script>

Controller:

 @RequestMapping(value="acceptJsonByMap") @ResponseBody public Map<String,Object> acceptJsonByMap(@RequestBody Map<String,Object> paramsMap, HttpServletRequest request){  System.out.println("當前http請求方式為:"+request.getMethod());  System.out.println(paramsMap);  return paramsMap; }

控制臺輸出:當前http請求方式為:POST {bookName=Love, author=Frank}

客戶端(彈窗):bookName =Love; author=Frank

三、以list方式接收(以json數組形式傳遞)

客戶端:

<button onclick="clickHere()">clickHere</button><script> function clickHere() {  var params1 = {   "bookId":"123",   "author":"Rose"  };  var params2 = {   "bookId":"321",   "author":"Jack"  };  var list = [];  list.push(params1);  list.push(params2);  $.ajax({   type: 'POST',   contentType:'application/json',   url: "acceptJsonByList",   data: JSON.stringify(list),   dataType: 'json',   success: function (data) {    for (let i = 0; i < data.length; i++) {     var bookId = data[i].bookId;     var author = data[i].author;     alert("bookId ="+bookId+"; author="+author);    }   },   error: function (data) {    alert("失敗啦");   }  }); }</script>

注意:傳遞到后端時,list應為[ { key1 : value1}{ key2 : value2} ]的json格式數據,否則可能會出現Json parse error錯誤。

Controller:

 @RequestMapping(value="acceptJsonByList") @ResponseBody public List<Book> acceptJsonByList(@RequestBody List<Book> book, HttpServletRequest request){  System.out.println("當前http請求方式為:"+request.getMethod());  System.out.println(book);  return book; }

注意:這里需要Book實體類進行接收。

控制臺輸出:當前http請求方式為:POST [entity.Book@1138a75c, entity.Book@22d1cbcf]

客戶端(彈窗):bookId =123; author=Rose bookId =321; author=Jack

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
国产福利微拍精品一区二区| 在线观看免费观看在线91| 国产福利在线视频| 国产网友自拍视频导航网站在线观看| 国产91足控脚交在线观看| 国产精品美女视频免费观看软件| 国产福利微拍精品一区二区| 在线一区二区三区精品| 欧美日韩一区二区三区在线播放| 国产在线视频福利| 国产极品嫩模在线视频一区| 伊人电影在线观看| 成人免费一区二区三区牛牛| 国产图片综合| 四虎国产精品永久在线| 国产免费一级片| 2021av天天| 国产美女在线观看| 午夜在线视频播放| 国产久草在线| 在线视频中文字幕| 九九在线免费视频| 99热免费在线观看| 中文字幕国产欧美| 日本在线视频www鲁啊鲁| 午夜国产福利在线| 免费a级毛片在线播放| 伊人av免费在线观看| 国产在线观看色| 亚洲成a人v欧美综合天堂麻豆| 久久五月精品| 超碰91在线| www.夜夜操.com| 伊人av免费在线观看| 国产小视频在线观看| 久久av少妇| 成人精品福利| 久久99亚洲网美利坚合众国| 亚洲字幕成人中文在线观看| 国产黄色网页| 国产精品欧美色图| 中文字幕在线影视资源| 免费看av大片| 黄色网页网址在线免费| 男人天堂99| 看成年女人免费午夜视频| 日本高清不卡中文字幕 | 国产伦精品一区二区三区高清版禁| 尤物视频在线观看| 国产视频青青| 91精品国产高久久久久久五月天| 中文字幕在线视频观看| 国产一二三区在线观看| 国产精品你懂的在线观看| 国产黄色在线网站| 亚洲欧洲成人| 成在在线免费视频| 国产三区四区在线观看| 中文天堂av| 超碰在线网址| 国产区成人精品视频| 99re在线视频| 激情综合丁香| 国产小视频在线播放| 99久久99热久久精品免费看| 人成在线免费视频| 国产精品免费麻豆入口| 四虎精品视频| 国产蜜臀在线| 在线视频观看你懂的| 欧美性xxxx交| 国产福利片在线| 免费av在线| 777电影在线观看| 国内外激情在线| 伊人久久青青草| 日本中文字幕在线看| 中文在线视频观看| 黄网址在线播放免费| 91社区在线观看| 中文字幕网在线| 麻豆精品传媒视频观看| 精品国产高清a毛片无毒不卡| 九色精品视频在线观看| 2021av天天| 国产亚洲精品久久久久久青梅 | 99re热视频在线| 国产美女视频一区二区三区 | 永久免费不卡在线观看黄网站| 国产在线拍揄自揄拍视频| 精品卡1卡2卡三卡免费网站| 午夜视频在线免费| 久久久久久久久久久久网站| 亚洲xxxxxx| 亚洲字幕成人中文在线观看| 国产日本在线观看| 国产精品178页| 国产wwww| 亚洲夜夜综合| 97视频免费| 在线三级av| 日本在线观看| gogo高清在线播放免费| 亚洲日本一区二区三区在线观看 | 亚洲精品aaaa精品| 在线观看免费视频一区二区三区| 国产三级视频| 在线中文av| 亚洲电影先锋| www亚洲天堂| 狠狠操视频网站| 国产美女性感在线观看懂色av| 青青艹在线视频| 国产九九九九| 国产黄色免费电影| 中文岛国精品亚洲一区| 四虎成人免费| 黄污在线观看| 国产二区视频在线观看| 亚洲精品xxxxx| 九七电影韩国女主播在线观看| 九九热在线视频观看| 国产美女在线播放| 精品国产高清a毛片无毒不卡 | 国产中文字幕在线视频| 国产免费av高清在线| 中文字幕在线观看av| 国产黄大片在线观看画质优化| 中文国产字幕在线观看| 日本啊v在线| 国产精品久久麻豆| 欧美xxxx黑人又粗又长| 日本中文字幕高清视频| 在线视频色在线| 国产一卡2卡3卡四卡网站 | 在线观看的av网站| 黄色国产在线| 99色在线观看| 国产一二区视频| 天天激情综合| 国产三区四区在线观看| 人xxxx性xxxxx欧美| 92国产在线视频| 丁香视频五月| 啪啪免费视频一区| 97影院秋霞午夜在线观看| 天天爱天天色| 欧美日韩**字幕一区| 在线亚洲电影| 国产一级黄色| 国产精品综合久久久久| 男人天堂网在线观看| 一区二区三区免费视频网站| 国产精品第八页| 国产一卡2卡3卡4卡网站免费| 超碰在线人人| 免费看的av| 久热中文字幕精品视频在线| 亚洲www色| 日韩国产成人| 男人天堂网在线观看| 欧美xxxxx性| 九七电影韩国女主播在线观看| 欧美专区日韩| 欧美黑人乱大交ⅹxxxxx| 四虎a级欧美在线观看| 亚洲天堂二区| 亚洲欧美中文字幕在线观看| 97最新国自产拍视频在线完整在线看 | 资源视频在线播放免费| 国产自产视频| 最近中文字幕mv免费高清电影 | 中文字幕在线视频免费观看| 国产精品一二三区视频| 日本中文字幕视频在线| 最近中文字幕mv免费高清电影| 国产一级二级在线| 国产成人亚洲综合小说区| 国产youjizz在线| 日本在线视频www鲁啊鲁| 超碰97在线免费观看| 久久99国产视频| 中文字幕视频在线| 99热国产在线| 久久精品国产亚洲777| 久久香蕉一区| 国产裸舞福利在线视频合集| 自拍av在线| 在线免费观看黄色av| 久久香蕉一区| 91亚洲欧美| 国产美女视频一区二区三区| 国产激情在线视频| 开心激情五月婷婷| 国产网红女主播精品视频| 亚洲欧美自拍另类| 国产一卡2卡3卡免费网站| 亚洲成av人影片在线观看| 在线91av| 久热国产在线|