SpringMVC接收與響應(yīng)json數(shù)據(jù)的幾種方式
前言
前后端的數(shù)據(jù)交互,除了通過form表單進行提交外,也可以通過ajax向后端傳遞和接收json格式數(shù)據(jù)(這種方式可以實現(xiàn)請求數(shù)據(jù)和頁面分離)。本文將總結(jié)一下在Spring MVC中接收和響應(yīng)json數(shù)據(jù)的幾種方式。
話不多說了,來一起看看詳細的介紹吧
準備步驟:
1.導(dǎo)入json相關(guān)框架的依賴(比如jackson)。
2.spring mvc的controller方法正常寫,如果需要響應(yīng)json,增加@responsebody注解。
3.在接受json對應(yīng)的輸入?yún)?shù)前,加上@RequestBody注解。
服務(wù)端接收json數(shù)據(jù)還原為java對象,稱為反序列化,反之,將java對象作為響應(yīng)轉(zhuǎn)換為json數(shù)據(jù)發(fā)回給客戶端,稱為序列化。
注意:因為要使用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傳遞的參數(shù)較多時,采用參數(shù)名匹配的方法不太方便。如果后臺有對應(yīng)的實體類,這時可以選擇在客戶端將數(shù)據(jù)封裝為json格式傳遞給后臺,后臺用對應(yīng)的實體類進行接收。
客戶端:
<button onclick="clickMe()">點我</button>
<script>
function clickMe() {
$.ajax({
type : 'POST',
url : "acceptJsonByEntity",
contentType : "application/json;charset=utf-8",
// 如果想以json格式把數(shù)據(jù)提交到后臺的話,JSON.stringify()必須有,否則只會當做表單提交
data : JSON.stringify({
"bookId" : 1,
"author" : "Jack"
}),
// 期待返回的數(shù)據(jù)類型
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的方法返回的對象通過適當?shù)霓D(zhuǎn)換器轉(zhuǎn)換為指定的格式之后,寫入到response對象的body區(qū),通常用來返回JSON數(shù)據(jù)或者是XML。
@RequestBody注解常用來處理content-type不是默認的application/x-www-form-urlcoded編碼的內(nèi)容。一般情況下來說常用其來處理application/json類型。
Controller:
@Controller
public 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格式數(shù)據(jù),可以使用@RestController注解。
@RestController = @Controller + @ResponseBody
Controller(上面的Controller可以用下面的替換):
@RestController
public 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方式接收
背景:前臺向后臺發(fā)送ajax請求并且攜帶很多參數(shù),而后臺并沒有對應(yīng)的實體類進行接收又該如何處理呢?最常見的就是表單,這里可以考慮使用map來解決。因為map的數(shù)據(jù)結(jié)構(gòu)為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();
//得到搜索框數(shù)據(jù)
var map = new Map();
$("#bookForm input").each(function () {
var value = $(this).val(); //input 值
var name = $(this).attr('name');
map.set(name,value);
})
//Map轉(zhuǎn)為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數(shù)組形式傳遞)
客戶端:
<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應(yīng)為[ { key1 : value1}{ key2 : value2} ]的json格式數(shù)據(jù),否則可能會出現(xiàn)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
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。
相關(guān)文章
關(guān)于Java8的foreach中使用return/break/continue產(chǎn)生的問題
這篇文章主要介紹了關(guān)于Java8的foreach()中使用return/break/continue產(chǎn)生的問題,在使用foreach()處理集合時不能使用break和continue這兩個方法,也就是說不能按照普通的for循環(huán)遍歷集合時那樣根據(jù)條件來中止遍歷,需要的朋友可以參考下2023-10-10
java實現(xiàn)文件和base64相互轉(zhuǎn)換
這篇文章主要為大家詳細介紹了java如何實現(xiàn)文件和base64相互轉(zhuǎn)換,文中的示例代碼講解詳細,具有一定的參考價值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-11-11
Java數(shù)據(jù)結(jié)構(gòu)超詳細分析二叉搜索樹
二叉搜索樹是以一棵二叉樹來組織的。每個節(jié)點是一個對象,包含的屬性有l(wèi)eft,right,p和key,其中,left指向該節(jié)點的左孩子,right指向該節(jié)點的右孩子,p指向該節(jié)點的父節(jié)點,key是它的值2022-03-03

