@ResponseBody 和 @RequestBody 的作用
阿新 • • 發佈:2018-12-20
先提一嘴 @RequestMapping(“url”)
,這裡的 url寫的是請求路徑的一部分,一般作用在 Controller
的方法上,作為請求的對映地址。
程式碼:
@RequestMapping(value = "/test")//類級別對映,可以沒有,一般用於減少書寫量
public class myController {
//方法級別對映,必須有,那麼這個方法的訪問地址就是/test/aaa,請求到的頁面就是test.jsp【當然,這裡的.jsp需要在配置檔案中配置】
@RequestMapping(value = "/aaa")
public String getMyName() {
return "test";
}
}
那麼 @ResponseBody呢?
@ResponseBody是作用在方法上的,@ResponseBody 表示該方法的返回結果直接寫入 HTTP response body 中,一般在非同步獲取資料時使用【也就是AJAX】,在使用 @RequestMapping後,返回值通常解析為跳轉路徑,但是加上 @ResponseBody 後返回結果不會被解析為跳轉路徑,而是直接寫入 HTTP response body 中。 比如非同步獲取 json 資料,加上 @ResponseBody 後,會直接返回 json 資料。@RequestBody 將 HTTP 請求正文插入方法中,使用適合的 HttpMessageConverter 將請求體寫入某個物件。
舉個例子:
前臺非同步請求:
function loginAction() {
// 獲取使用者輸入的賬號和密碼
var name = $('#count').val();
var password = $('#password').val();
$.ajax({
url : 'account/login.do',
type : 'post',
// data物件中的屬性名要和服務端控制器的引數名一致 login(name, password)
data : {
'name' : name,
'password' : password
},
dataType : 'json',
success : function(result) {
if (result.state == 0) {
// 登入成功,設定cookie並跳轉edit.html
addCookie('userId', result.data.id);
addCookie('nick', result.data.nick);
location.href = 'edit.html';
} else {
// 登入失敗
var msg = result.message;
$('#sig_in').next().html(msg);
$('#sig_in').next().css("color", "red");
}
},
error : function(e) {
alert("系統異常");
}
});
$('#password').val("");
}
後臺 Controller類中對應的方法:
@RequestMapping("/login.do")
@ResponseBody
public Object login(String name, String password, HttpSession session) {
user = userService.checkLogin(name, password);
session.setAttribute("user", user);
return new JsonResult(user);
}
@RequestBody呢?
@RequestBody是作用在形參列表上,用於將前臺傳送過來固定格式的資料【xml 格式或者 json等】封裝為對應的 JavaBean 物件,封裝時使用到的一個物件是系統預設配置的 HttpMessageConverter進行解析,然後封裝到形參上。
比如上面的登入後臺程式碼可以改為:
@RequestMapping("/login.do")
@ResponseBody
public Object login(@RequestBody User loginUuser, HttpSession session) {
user = userService.checkLogin(loginUser);
session.setAttribute("user", user);
return new JsonResult(user);
}