SpringMVC @RequestMapping controller方法的返回值

 @RequestMapping

  10.1 Url路徑映射

@RequestMapping(value="/item")@RequestMapping("/item)

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

 

定義controller方法對應的url,進行處理器映射使用。通過RequestMapping註解可以定義不同的處理器映射規則。

 

  10.2 窄化請求映射

在class上添加@RequestMapping(url)指定通用請求前綴, 限制此類下的所有方法請求url必須以請求前綴開頭,通過此方法對url進行分類管理。

 

如下:

@RequestMapping放在類名上邊,設置請求前綴 

@Controller

@RequestMapping("/item")

 

方法名上邊設置請求映射url:

@RequestMapping放在方法名上邊,如下:

@RequestMapping("/queryItem ")

 

訪問地址爲:/item/queryItem

 

 

請求路徑發生變化:http://localhost:8080/springmvc_mybatis1217/items/editItems.action

修改鏈接也發生變化

  10.3 http請求方法限定

限定GET方法

@RequestMapping(method = RequestMethod.GET)

 

如果通過Post訪問則報錯:

HTTP Status 405 - Request method 'POST' not supported

 

例如:

@RequestMapping(value="/editItem",method=RequestMethod.GET)

限定POST方法

 

@RequestMapping(method = RequestMethod.POST)

 

如果通過Post訪問則報錯:

HTTP Status 405 - Request method 'GET' not supported

 

GET和POST都可以

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

 

出於安全性考慮,對http的鏈接進行方法限制。

如果限制請求爲post方法,進行get請求,報錯:

 

 

11 controller方法的返回值

  11.1 返回ModelAndView

需要方法結束時,定義ModelAndView,將model和view分別進行設置。

controller方法中定義ModelAndView對象並返回,對象中可添加model數據、指定view。

 

  11.2 返回string

如果controller方法返回string,

 

    11.2.1 表示返回邏輯視圖名。

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

 

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

 

真正視圖(jsp路徑)=前綴+邏輯視圖名+後綴

    11.2.2 2、redirect重定向

Contrller方法返回結果重定向到一個url地址,如下商品修改提交後重定向到商品查詢方法,參數無法帶到商品查詢方法中。

//重定向到queryItem.action地址,request無法帶過去
return "redirect:queryItem.action";

 

redirect方式相當於“response.sendRedirect()”,轉發後瀏覽器的地址欄變爲轉發後的地址,因爲轉發即執行了一個新的request和response。

由於新發起一個request原來的參數在轉發時就不能傳遞到下一個url,如果要傳參數可以/item/queryItem.action後邊加參數,如下:

/item/queryItem?...&..

 

需求:商品修改提交後,重定向到商品查詢列表。

redirect重定向特點:瀏覽器地址欄中的url會變化。修改提交的request數據無法傳到重定向的地址。因爲重定向後重新進行request(request無法共享)

 

    11.2.3 3、forward頁面轉發

controller方法執行後繼續執行另一個controller方法,如下商品修改提交後轉向到商品修改頁面,修改商品的id參數可以帶到商品修改方法中。

//結果轉發到editItem.action,request可以帶過去
return "forward:editItem.action";

 

 

forward方式相當於“request.getRequestDispatcher().forward(request,response)”,轉發後瀏覽器地址欄還是原來的地址。轉發並沒有執行新的request和response,而是和轉發前的請求共用一個request和response。所以轉發前請求的參數在轉發後仍然可以讀取到。

 

通過forward進行頁面轉發,瀏覽器地址欄url不變,request可以共享。

 

 

  11.3 返回void

 

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

1、使用request轉向頁面,如下:

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

 

2、也可以通過response頁面重定向:

response.sendRedirect("url")

 

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

response.setCharacterEncoding("utf-8");

response.setContentType("application/json;charset=utf-8");

response.getWriter().write("json串");

最能讓人感到快樂的事,莫過於經過一番努力後,所有東西正慢慢變成你想要的樣子!
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章