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屬性默認為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"; }
復(fù)雜實體對象:請求參數(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請求響應(yīng)的文章就介紹到這了,更多相關(guān)SpringBoot請求響應(yīng)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Springboot應(yīng)用gradle?Plugin示例詳解
這篇文章主要介紹了Springboot應(yīng)用gradle?Plugin詳解,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04