SpringBoot請求響應方式示例詳解
一、簡單參數(shù)
原始方式(過于繁瑣了解即可)
在原始的web程序中,獲取請求參數(shù),需要通過HttpServletRequest對象手動獲取。
@RequestMapping("/simpleParam")
public String simpleParam(HttpServletRequest request){
String name=request.getParameter("name");
String ageStr=request.getParameter("age");
int age=Integer.parseInt(ageStr);
System.out.println(name+","+age);
return "ok";
}public String simpleParam(HttpServletRequest request):這是一個公共方法,返回類型為String。它接收一個HttpServletRequest類型的參數(shù),用于獲取HTTP請求的信息。
String name=request.getParameter("name");:從HTTP請求中獲取名為"name"的參數(shù)值,并將其賦值給變量name。
int age=Integer.parseInt(ageStr);:將字符串類型的ageStr轉(zhuǎn)換為整數(shù)類型,并賦值給變量age。
SpringBoot方式
簡單參數(shù):參數(shù)名與形參變量名相同,定義形參即可接收參數(shù)。
@RequestMapping("/simpleParam")
public String simpleParam(String name,Integer age){
System.out.println(name+","+age);
return "ok";
}如果請求參數(shù)名 不一致,會導致接收失敗,但是不會報錯。 可以使用@RequestParam來完成映射。
@RequestMapping("/simpleParam")
public String simpleParam(@RequestParam(name="name") String username, Integer age){
System.out.println(username+","+age);
return "ok";
}@RequestParam中的required屬性默認為true,代表該請求參數(shù)必須傳遞,如果不傳遞將報錯。如果該參數(shù)是可選的必須將required屬性設(shè)置為false。


二、實體參數(shù)
User實體類代碼如下:
package com.example.demo.pojo;
public class User {
private String name;
private Integer age;
public User(String name, Integer age) {
this.name = name;
this.age = age;
}
public User() {
}
@Override
public String toString() {
return "User{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
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;
}
}簡單實體對象:請求參數(shù)與形參對象屬性名相同,定義POJO接收即可。
@RequestMapping("/simplePojo")
public String simplePojo(User user){
System.out.println(user);
return "ok";
}復雜實體對象:請求參數(shù)名與形參對象屬性名相同,按照對象層次結(jié)構(gòu)關(guān)系即可接收嵌套POJO屬性參數(shù)。
![]()
三、數(shù)組集合參數(shù)
數(shù)組參數(shù):請求參數(shù)名與形參數(shù)組名稱相同且請求參數(shù)為多個,定義數(shù)組類型形參即可接收參數(shù)。
@RequestMapping("/arrayParam")
public String arrayParam(String [] hobby){
System.out.println(Arrays.toString(hobby));
return "ok";
}集合參數(shù):請求參數(shù)名與形參集合名稱相同且請求參數(shù)為多個,@RequestParam綁定參數(shù)關(guān)系,默認情況下多個值封裝在數(shù)組中。
@RequestMapping("/listParam")
public String listParam(@RequestParam List<String> hobby){
System.out.println(hobby);
return "ok";
}四、日期參數(shù)
日期參數(shù):使用@DateTimeFormat注解完成日期參數(shù)格式轉(zhuǎn)換,指定前端傳遞日期的格式。
@RequestMapping("/dateParam")
public String dateParam(@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") LocalDateTime updateTime){
System.out.println(updateTime);
return "ok";
}五、JSON參數(shù)
JSON參數(shù):JSON數(shù)據(jù)鍵名與形參對象屬性名形同,定義POJO類型形參即可接收參數(shù),需要使用@RequestBody標識。
@RequestMapping("/jsonParam")
public String jsonParam(@RequestBody User user){
System.out.println(user);
return "ok";
}六、路徑參數(shù)
路徑參數(shù):通過請求URL直接傳遞參數(shù),使用{...}來表示該路徑參數(shù),需要使用@PathVariable獲取路徑參數(shù)。(可獲取多個參數(shù),直接在后面添加/{...}/{...})
@RequestMapping("/path/{id}")
public String pathParam(@PathVariable Integer id){
System.out.println(id);
return "ok";
}到此這篇關(guān)于SpringBoot請求響應的文章就介紹到這了,更多相關(guān)SpringBoot請求響應內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

