SpringBoot請求響應(yīng)方式示例詳解
一、簡單參數(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ù)名 不一致,會導(dǎo)致接收失敗,但是不會報錯。 可以使用@RequestParam來完成映射。
@RequestMapping("/simpleParam")
public String simpleParam(@RequestParam(name="name") String username, Integer age){
System.out.println(username+","+age);
return "ok";
}@RequestParam中的required屬性默認(rèn)為true,代表該請求參數(shù)必須傳遞,如果不傳遞將報錯。如果該參數(shù)是可選的必須將required屬性設(shè)置為false。


二、實(shí)體參數(shù)
User實(shí)體類代碼如下:
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í)體對象:請求參數(shù)與形參對象屬性名相同,定義POJO接收即可。
@RequestMapping("/simplePojo")
public String simplePojo(User user){
System.out.println(user);
return "ok";
}復(fù)雜實(shí)體對象:請求參數(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)系,默認(rè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標(biāo)識。
@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請求響應(yīng)的文章就介紹到這了,更多相關(guān)SpringBoot請求響應(yīng)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java創(chuàng)建多級目錄文件的實(shí)例講解
下面小編就為大家分享一篇java創(chuàng)建多級目錄文件的實(shí)例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01
Springboot應(yīng)用gradle?Plugin示例詳解
這篇文章主要介紹了Springboot應(yīng)用gradle?Plugin詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04
springboot項(xiàng)目中使用Swagger的簡單示例
大趨勢下目前很多的項(xiàng)目都采用了前后端分離的方式進(jìn)行開發(fā),最近我接觸到的項(xiàng)目大多數(shù)都是采用了前后端分離的方式進(jìn)行開發(fā),下面這篇文章主要給大家介紹了關(guān)于springboot項(xiàng)目中使用Swagger的簡單示例,需要的朋友可以參考下2023-04-04
spring mvc4中相關(guān)注解的詳細(xì)講解教程
這篇文章主要給大家介紹了關(guān)于spring mvc4中相關(guān)注解的相關(guān)資料,其中詳細(xì)介紹了關(guān)于@Controller、@RequestMapping、@RathVariable、@RequestParam及@RequestBody等等注解的相關(guān)內(nèi)容,需要的朋友可以參考借鑒,下面來一起看看吧。2017-06-06

