SpringMVC的@RequestMapping和Controller方法返回值


本節內容:

  • @RequestMapping
  • Controller方法返回值

 

一、@RequestMapping

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

1. URL路徑映射

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

value的值是數組,可以將多個url映射到同一個方法。

/**
 * 查詢商品列表
 * @return
 */
@RequestMapping(value = { "itemList", "itemListAll" })
public ModelAndView queryItemList() {
	// 查詢商品數據
	List<Item> list = this.itemService.queryItemList();

	// 創建ModelAndView,設置邏輯視圖名
	ModelAndView mv = new ModelAndView("itemList");

	// 把商品數據放到模型中
	mv.addObject("itemList", list);
	return mv;
}

 

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。

	@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);

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

 

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

response.sendRedirect("url")

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

  

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

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

代碼:

    /**
     * 返回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方法返回字符串可以指定邏輯視圖名,通過視圖解析器解析為物理視圖地址。

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

示例代碼:

    /**
     * 根據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地址。

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

   /**
     * 更新商品
     *
     * @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參數可以帶到商品修改方法中。

    /**
     * 更新商品
     *
     * @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";

    }

  

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM