1. 程式人生 > >SpringMVC的@RequestMapping和Controller方法返回值

SpringMVC的@RequestMapping和Controller方法返回值

【原文:https://www.cnblogs.com/zhaojiankai/p/8184207.html

 

本節內容:

  • @RequestMapping
  • Controller方法返回值

 

一、@RequestMapping

通過@RequestMapping註解可以定義不同的處理器對映規則。

1. URL路徑對映

@RequestMapping(value="/item") 或 @RequestMapping("/item")   --當括號裡有多個屬性時,value=不可以省略。

value的值是陣列,可以將多個url對映到同一個方法。

+ View Code

 

2. 新增在類上面

在class上新增@RequestMapping(url)指定通用請求字首,限制此類下的所有方法請求url必須以請求字首開頭

可以使用此方法對url進行分類管理,如下圖:

此時需要進入queryItemList()方法的請求url為:http://127.0.0.1:8080/api/item/itemList.action

或者

http://127.0.0.1:8080/api/item/itemListAll.action

 

3. 請求方法限定 

除了可以對url進行設定,還可以限定請求進來的方法。不寫的話預設所有方法都可以。

(1)限定GET方法

@RequestMapping(method = RequestMethod.GET)

如果通過POST訪問則報錯:
HTTP Status 405 - Request method 'POST' not supported

例如:
@RequestMapping(value = "itemList",method = RequestMethod.POST)

 

(2)限定POST方法

@RequestMapping(method = RequestMethod.POST)

如果通過GET訪問則報錯:
HTTP Status 405 - Request method 'GET' not supported

 

(3)GET和POST都可以

@RequestMapping(method = {RequestMethod.GET,RequestMethod.POST})

 

二、Controller方法返回值

1. 返回ModelAndView  --無敵的,帶著資料,返回檢視路徑

controller方法中定義ModelAndView物件並返回,物件中可新增model資料、指定view。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

@RequestMapping(value = "/item/itemlist.action")

public ModelAndView itemList(){

     

    // 從MySQL中查詢資料

    List<Items> list = itemService.selectItemsList();

 

    // 建立ModelAndView,用來存放資料和檢視

    ModelAndView mav = new ModelAndView();

    // 設定資料到模型中

    mav.addObject("itemList", list); //頁面上迴圈的是itemList

    // 設定檢視的路徑,需要設定檢視的實體地址

    //mav.setViewName("/WEB-INF/jsp/itemList.jsp");

    mav.setViewName("itemList"); //在springmvc.xml中替換掉預設的檢視解析器

 

    return mav;

}

 

2. 返回void  --資料通過形參 Model model 或者 ModelMap model,但是沒辦法return檢視。如果需要返回檢視得通過request或response。這種比較適合ajax請求,但是給ajax返回資料得json格式資料。

在Controller方法形參上可以定義request和response,使用request或response指定響應結果:

(1)使用request轉發頁面,如下:

request.getRequestDispatcher("頁面路徑").forward(request, response);

1

request.getRequestDispatcher("/WEB-INF/jsp/success.jsp").forward(request, response);

 

(2)可以通過response頁面重定向:

response.sendRedirect("url")

1

response.sendRedirect("/itemEdit.action");

  

(3)可以通過response指定響應結果,例如響應json資料如下:

1

response.getWriter().print("{\"abc\":123}");

程式碼:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

/**

 * 返回void測試

 *

 * @param request

 * @param response

 * @throws Exception

 */

@RequestMapping("queryItem")

public void queryItem(HttpServletRequest request, HttpServletResponse response) throws Exception {

    // 1 使用request進行轉發

    // request.getRequestDispatcher("/WEB-INF/jsp/success.jsp").forward(request,

    // response);

 

    // 2 使用response進行重定向到編輯頁面

    // response.sendRedirect("/springmvc-web2/itemEdit.action");

 

    // 3 使用response直接顯示

    response.getWriter().print("{\"abc\":123}");

}

【注意】:改對映@RequestMapping、改方法名、改方法形參、改返回值都需要重啟程式,其他不需要重啟。

 

3. 返回字串(官方推薦此種方式)   --返回檢視路徑,資料通過形參 Model model 或者 ModelMap model

(1)邏輯檢視名

controller方法返回字串可以指定邏輯檢視名,通過檢視解析器解析為物理檢視地址。

1

2

//指定邏輯檢視名,經過檢視解析器解析為jsp物理路徑:/WEB-INF/jsp/itemList.jsp

return "itemList";

示例程式碼:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

/**

 * 根據id查詢商品,繫結簡單資料型別

 *

 * @param id

 * @param model

 * @return

 */

@RequestMapping("/itemEdit.action")

public String queryItemById(Integer id, ModelMap model) { //不要用int,萬一傳進來一個long

    // 根據id查詢商品資料

    Items item = this.itemService.selectItemsById(id);

 

    // 把商品資料放在模型中

    model.addAttribute("item", item);

 

    return "editItem";

}

  

(2)Redirect重定向

Contrller方法返回字串可以重定向到一個url地址。

如下商品修改提交後重定向到商品編輯頁面。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

/**

  * 更新商品

  *

  * @param item

  * @return

  */

 @RequestMapping("updateItem")

 public String updateItemById(Items item) {

     // 更新商品

     this.itemService.updateItemById(item);

 

     // 修改商品成功後,重定向到商品編輯頁面

     // 重定向後瀏覽器位址列變更為重定向的地址,

     // 重定向相當於執行了新的request和response,所以之前的請求引數都會丟失

     // 如果要指定請求引數,需要在重定向的url後面新增 ?itemId=1 這樣的請求引數

     return "redirect:/itemEdit.action?itemId=" + item.getId();

 }

  

(3)forward轉發

Controller方法執行後繼續執行另一個Controller方法

如下商品修改提交後轉向到商品修改頁面,修改商品的id引數可以帶到商品修改方法中。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

/**

 * 更新商品

 *

 * @param item

 * @return

 */

@RequestMapping("updateItem")

public String updateItemById2(Items item) {

    // 更新商品

    this.itemService.updateItemById(item);

 

    // 修改商品成功後,重定向到商品編輯頁面

    // 重定向後瀏覽器位址列變更為重定向的地址,

    // 重定向相當於執行了新的request和response,所以之前的請求引數都會丟失

    // 如果要指定請求引數,需要在重定向的url後面新增 ?itemId=1 這樣的請求引數

    // return "redirect:/itemEdit.action?itemId=" + item.getId();

 

    // 修改商品成功後,繼續執行另一個方法

    // 使用轉發的方式實現。轉發後瀏覽器位址列還是原來的請求地址,

    // 轉發並沒有執行新的request和response,所以之前的請求引數都存在

    return "forward:/itemEdit.action";

 

}