## SpringMVC如何接受請求參數(普通類型參數/對象類型參數/數組/json數據等) 1、普通類型參數 (1)在可以在方法參數上使用@RequestParam註解來綁定請求參數,此註解允許指定請求參數的名稱,以及是否是必須傳的參數。 ~~~java @RequestMapping("/exa ...
SpringMVC如何接受請求參數(普通類型參數/對象類型參數/數組/json數據等)
1、普通類型參數
(1)在可以在方法參數上使用@RequestParam註解來綁定請求參數,此註解允許指定請求參數的名稱,以及是否是必須傳的參數。
@RequestMapping("/example")
public String exampleMethod(@RequestParam("paramName") String param) {
// 處理參數
return "viewName";
}
(2)如果需要傳的參數是URL的一部分,可以使用@PathVariable註解來綁定路徑參數。
@RequestMapping("/example/{id}")
public String exampleMethod(@PathVariable("id") int id) {
// 處理路徑參數
return "viewName";
}
2、對象類型參數
常用的是@RequestBody註解,如果請求的內容是json或xml格式的數據,並且希望將其轉為對象,可以使用@RequestBody註解,springmvc將自動進行請求體到對象的轉換。
3、數組類型
(1)@RequestParam註解,通過此註解來綁定請求參數到數組,使用“value”屬性指定請求參數的名稱,並將方法參數聲明為數組類型。
@RequestMapping("/example")
public String exampleMethod(@RequestParam("myArray") String[] array) {
// 處理數組
return "viewName";
}
(2)如果請求的路徑中有多個參數值,這些參數值通過“/”進行分離,可以使用@PathVariable註解綁定這些參數到數組。
@RequestMapping("/example/{values}")
public String exampleMethod(@PathVariable("values") String[] array) {
// 處理數組
return "viewName";
}
4、Json數據
你可以使用 @RequestBody 註解來接收 JSON 類型的請求參數。Spring MVC 將自動將請求的 JSON 數據轉換為對象。在控制器方法中,使用@RequestBody註解,並將接收json數據的對象作為方法參數。
@RequestMapping("/example")
public String exampleMethod(@RequestBody MyObject obj) {
// 處理接收到的 JSON 數據
return "viewName";
}
當 Spring MVC 接收到請求時,它會自動將請求的 JSON 數據轉換為 MyObject
對象,並傳遞給控制器方法。
如何給客戶端響應數據(跳轉頁面&返回數據)?
(1)可以通過返回視圖名稱。返回一個視圖名稱,告訴springmvc渲染對應的視圖,然後作為響應發送給客戶端。
(2)使用ModelAndAview。創建一個ModelAndView對象,把數據模型添加到MV中,並設置視圖名,然後返回對象。springmvc會根據視圖名稱渲染對應的視圖。
(3)如果想要一個json類型或者xml格式的數據,也可以使用@ResponseBody註解。
@RequestBody與@ResponseBody的區別
@RequestBody
和 @ResponseBody
是 Spring MVC 中用於處理請求和響應體的註解,它們有以下區別:
-
@RequestBody:
-
作用:
@RequestBody
用於將請求體的內容綁定到方法參數上。 -
使用場景:通常在處理 POST、PUT 等請求方法時,用於接收請求體中的數據,並將其轉換為對象或其他類型的參數。
-
示例:
@RequestMapping("/example") public String exampleMethod(@RequestBody MyObject obj) { // 處理接收到的請求體數據 return "response"; }
-
-
@ResponseBody:
-
作用:
@ResponseBody
用於將方法返回值直接作為響應體的內容返回給客戶端。 -
使用場景:通常在返回 JSON、XML 或其他格式的響應時使用,將對象或其他類型的數據轉換為響應體的內容。
-
示例:
@RequestMapping("/example") @ResponseBody public MyObject exampleMethod() { MyObject obj = new MyObject(); // 處理數據並設置到 obj return obj; }
-
註意:在 Spring 4.0 之後,預設情況下,
@ResponseBody
註解不再需要顯式聲明。如果你使用了 Spring 4.0 或更高版本,而且沒有自定義的配置,Spring MVC 會自動將方法返回值作為響應體返回給客戶端。
-
綜上所述,@RequestBody
主要用於將請求體的內容綁定到方法參數上,而 @ResponseBody
用於將方法返回值直接作為響應體的內容返回給客戶端。它們在處理請求和響應體時起到不同的作用,但可以組合使用,實現接收請求體並返回自定義格式的響應。