SpringMVC中@ResponseBody 和 @RequestBody 的作用
阿新 • • 發佈:2019-01-07
@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);
}