一篇了解springboot3請求參數種類及接口測試
SpringBoot3數據請求:
原始數據請求:
//原始方式
@RequestMapping("/simpleParam")
public String simpleParam(HttpServletRequest request){
//獲取請求參數
String name = request.getParameter("name");
String age = request.getParameter("age");
int age1 = Integer.parseInt(age);
System.out.println(name+":"+ age1);
return "ok";
}
springboot數據請求方式:
//springboot方式
@RequestMapping("/simpleParam")
public String simpleParam(String name,Integer age){
//獲取請求參數
System.out.println(name+":"+ age);
return "ok";
}
**
一、簡單實體參數:
**
@RequestParam注解的使用:方法形參名稱與請求參數名稱不匹配,可以使用@RequestParam完成映射。


@RequestMapping("/simpleParam")
public String simpleParam(@RequestParam(name="name",required = false) String username,Integer age){
//獲取請求參數
System.out.println(username+":"+ age);
return "ok";
}
@RequestParam中的required屬性默認為true,代表該請求參數必須傳遞,如果不傳遞將報錯,如果該參數是可選中,可以將required屬性設置為false。
如下圖所示:


二、實體對象參數
規則:請求參數名與形參對象屬性名相同,即可直接通過pojo接收。
User實體類
public class User {
private String name;
private Integer age;
private Address address;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public Address getAddress() {
return address;
}
public void setAddress(Address address) {
this.address = address;
}
@Override
public String toString() {
return "User{" +
"name='" + name + '\'' +
", age=" + age +
", address=" + address +
'}';
}
Address實體類
public class Address {
private String province;
private String city;
public String getProvince() {
return province;
}
public void setProvince(String province) {
this.province = province;
}
public String getCity() {
return city;
}
public void setCity(String city) {
this.city = city;
}
@Override
public String toString() {
return "Address{" +
"province='" + province + '\'' +
", city='" + city + '\'' +
'}';
}


三、數組集合參數:
數組參數: 請求參數名與形參數組名稱相同且請求參數為多個,定義數組類形參即可接受參數。
//數組集合參數
@RequestMapping("/arrayParam")
public String arrayParam(String[] hobby){
System.out.println(Arrays.toString(hobby));
return "ok";
}


集合參數: 請求參數名與形參集合名稱相同且請求參數為多個,@RequestParam綁定參數關系
@RequestMapping("/listParam")
public String listParam(@RequestParam List<String> hobby){
System.out.println(hobby);
return "ok";
}


小結:
數組:請求參數名與形參中數組變量名相同,可以直接使用數組封裝
集合:請求參數名與形參中集合變量名相同,通過@RequestParam綁定參數關系
四、日期參數
日期參數: 使用@DateTimeFormat注解完成日期參數格式轉換
//日期時間參數
@RequestMapping("/dateParam")
public String dateParam(@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") LocalDateTime updateTime){
System.out.println(updateTime);
return "ok";
}


五、Json參數
Json參數: JSON數據鍵名與形參對象屬性名相同,定義POJO類型形參即可接收參數,需要使用@RequestBody標識
//json參數
@RequestMapping("/jsonParam")
public String jsonParam(@RequestBody User user){
System.out.println(user);
return "ok";
}


六、路徑參數
路徑參數: 通過請求url直接傳遞參數,使用{...}來標識該路徑參數,需要使用@PathVariable獲取路徑參數
//路徑參數
@RequestMapping("/path/{id}")
public String pathParam(@PathVariable Integer id){
System.out.println(id);
return "ok";
}
@RequestMapping("/path/{id}/{name}")
public String pathParam2(@PathVariable Integer id,@PathVariable String name){
System.out.println(id+":"+name);
return "ok";
}



總結
簡單參數:
- 定義方法形參,請求參數名與形參變量名一致
- 如果不一致,通過@RequestParam手動映射
實體參數:
- 請求參數名,與實體對象的屬性名一致,會自動接受封裝
數組集合參數:
- 數組:請求參數名與數組名一致,直接封裝
- 集合:請求參數名與集合名一致,@RequestParam綁定關系
日期參數:
- @DateTimeFormat
JSON參數:
- @RequestBody
路徑參數:
- PathVariable

浙公網安備 33010602011771號