SpringBoot接受前台參數的六種方式,首先因為從前台發送的請求沒有界面的話只能是從地址欄發送並且只能是Get請求,為了測試其他的請求,所以我們使用一個工具->Postman,Postman是一款功能強大的網頁調試與發送網頁HTTP請求的Chrome插件。
對於前台傳過來的參數大致分為六種,下面一個一個的做演示學習:演示之前先複習一下,沒用SpringBoot獲取前台參數的方式,透過request物件取得。
@RestController public class RequestController { //原始方式 @RequestMapping("/simpleParam") public String simpleParam(HttpServletRequest request){ // http://localhost:8080/simpleParam?name=Tom&age=10 // 请求参数: name=Tom&age=10 (有2个请求参数) // 第1个请求参数: name=Tom 参数名:name,参数值:Tom // 第2个请求参数: age=10 参数名:age , 参数值:10 String name = request.getParameter("name");//name就是请求参数名 String ageStr = request.getParameter("age");//age就是请求参数名 int age = Integer.parseInt(ageStr);//需要手动进行类型转换 System.out.println(name+" : "+age); return "OK"; } }
在Springboot的環境中,對原始的API進行了封裝,接收參數的形式更加簡單。如果是簡單參數,參數名稱與形參變數名稱相同,定義同名的形參即可接收參數。
@RestController public class RequestController { // http://localhost:8080/simpleParam?name=Tom&age=10 // 第1个请求参数: name=Tom 参数名:name,参数值:Tom // 第2个请求参数: age=10 参数名:age , 参数值:10 //springboot方式 @RequestMapping("/simpleParam") public String simpleParam(String name , Integer age ){//形参名和请求参数名保持一致 System.out.println(name+" : "+age); return "OK"; } }
如果後台需要但是前台並沒傳對應的參數,這個時候會回傳null
目前台傳的參數名稱和後台接受參數的方法形參列表不一致的時候,可以透過 @RequestParam(「」)來指定
@RestController public class RequestController { // http://localhost:8080/simpleParam?name=Tom&age=20 // 请求参数名:name //springboot方式 @RequestMapping("/simpleParam") public String simpleParam(@RequestParam("name") String username , Integer age ){ System.out.println(username+" : "+age); return "OK"; } }
另外@RequestParam中的required屬性預設為true(預設值也是true),代表該請求參數必須傳遞,如果不傳遞會報錯,如果該參數是可選的,可以將required屬性設定為false
程式碼如下:
@RequestMapping("/simpleParam") public String simpleParam(@RequestParam(name = "name", required = false) String username, Integer age){ System.out.println(username+ ":" + age); return "OK"; }
這個註解還有一個參數,是defaultValue表示如果前台沒有傳遞參數就預設為目前指定的值。
@RequestMapping("/simpleParam") public String simpleParam(@RequestParam(name = "name", required = false,defaultValue ="匿名用户") String userName, Integer age) { // 打印输出 System.out.println(userName+"----"+age); return "ok"; }
簡單實體物件:
在使用簡單參數做為資料傳遞方式時,前端傳遞了多少個請求參數,後端controller方法中的形參就要寫多少。如果請求參數比較多,透過上述的方式一個參數一個參數的接收,會比較繁瑣。
此時,我們可以考慮將請求參數封裝到一個實體類別物件中。要完成資料封裝,需要遵守以下規則:請求參數名稱與實體類別的屬性名稱相同
要求是前台傳過來的參數必須和物件中的參數名稱相同,順序相同。
@RestController public class RequestController { // http://localhost:8080/simpleParam?name=Tom&age=20 //实体参数:简单实体对象 User有两个属性,一个是name 一个是age,这样Spring就会自动完成赋值 @RequestMapping("/simplePojo") public String simplePojo(User user){ System.out.println(user); return "OK"; } }
複雜實體物件:物件套物件
比如說User中又多了一個欄位: Address 而這個類別又有兩個屬性,這個時候前台傳遞參數的時候就需要發生改變,後台還是用User接受
public class User { private String name; private Integer age; private Address address; //地址对象 ..... } public class Address { private String province; private String city; ..... }
方法代碼
@RestController public class RequestController { //实体参数:复杂实体对象 @RequestMapping("/complexPojo") public String complexPojo(User user){ System.out.println(user); return "OK"; } }
陣列集合參數的使用場景:在HTML的表單中,有一個表單項目是支援多選的(複選框),可以提交選擇的多個值。
xxxxxxxx?hobby=game&hobby=java
後端程式接收上述多個值的方式有兩種:
請求參數名稱與形參數組名稱相同且請求參數為多個,定義數組類型形參即可接收參數
@RestController public class RequestController { //数组集合参数 @RequestMapping("/arrayParam") public String arrayParam(String[] hobby){ System.out.println(Arrays.toString(hobby)); return "OK"; } }集合參數:
請求參數名稱與形參集合物件名稱相同且請求參數為多個,@RequestParam 綁定參數關係
預設情況下,請求中參數名稱相同的多個值,是封裝到陣列。如果要封裝到集合,要使用@RequestParam綁定參數關係Controller方法:
@RestController public class RequestController { //数组集合参数 @RequestMapping("/listParam") public String listParam(@RequestParam List<String> hobby){ System.out.println(hobby); return "OK"; } }4、日期參數上述示範的都是一些普通的參數,在一些特殊的需求中,可能會涉及到日期類型資料的封裝(其實我們一般都存字串,不會轉來轉去,所以這裡了解)。例如,以下需求: 因為日期的格式多元(如:2022-12-12 10:05:45 、2022/12/12 10:05: 45),那麼對於日期類型的參數在進行封裝的時候,就需要透過@DateTimeFormat註解,以及其pattern屬性來設定日期的格式。
@RestController public class RequestController { //日期时间参数 @RequestMapping("/dateParam") public String dateParam(@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") LocalDateTime updateTime){ System.out.println(updateTime); return "OK"; } }5、JSON參數在學習前端技術時,我們有講到過JSON,而在前後端進行交互作用時,如果是比較複雜的參數,前後端透過會使用JSON格式的資料進行傳輸。 (JSON是開發中最常用的前後端數據交互方式) ,其實我們也會看到, 後台如果返回給前台數據的時候,有的是字符串,又的是集合,有的是JSON, 那麼前台在解析的時候就十分的麻煩, 後來經過一個實體類別用來存放所有的資料, 然後返回這個物件, 這樣前台在接受的時候只要處理JSON就好.在筆記的最後會提到#
##下面介紹在Postman中怎麼發送JSON資料:
服务端Controller方法接收JSON格式数据:
传递json格式的参数,在Controller中会使用实体类进行封装。
封装规则:JSON数据键名与形参对象属性名相同,定义POJO类型形参即可接收参数。需要使用 @RequestBody标识。
@RequestBody注解:将JSON数据映射到形参的实体类对象中(JSON中的key和实体类中的属性名保持一致)
通过添加@RequestBody注解Spring可以自动的将JSON转换为对象.
实体类:
public class User { private String name; private Integer age; private Address address; //省略GET , SET 方法 }
@RestController public class RequestController { //JSON参数 @RequestMapping("/jsonParam") public String jsonParam(@RequestBody User user){ System.out.println(user); return "OK"; } }
传统的开发中请求参数是放在请求体(POST请求)传递或跟在URL后面通过?key=value的形式传递(GET请求)。
在现在的开发中,经常还会直接在请求的URL中传递参数。例如:
http://localhost:8080/user/1
http://localhost:880/user/1/0
上述的这种传递请求参数的形式呢,我们称之为:路径参数。
学习路径参数呢,主要掌握在后端的controller方法中,如何接收路径参数。
路径参数:
前端:通过请求URL直接传递参数
后端:使用{…}来标识该路径参数,需要使用@PathVariable获取路径参数
Controller方法:
@RestController public class RequestController { //路径参数 @RequestMapping("/path/{id}") public String pathParam(@PathVariable Integer id){ System.out.println(id); return "OK"; } }
传递多个路径参数:
@RestController public class RequestController { //路径参数 前台路径 xxxx/path/12/jack @RequestMapping("/path/{id}/{name}") public String pathParam2(@PathVariable Integer id, @PathVariable String name){ System.out.println(id+ " : " +name); return "OK"; } }
响应:
前面我们学习过HTTL协议的交互方式:请求响应模式(有请求就有响应)
那么Controller程序呢,除了接收请求外,还可以进行响应。先说一下使用到的注解:
@ResponseBody
类型:方法注解、类注解
位置:书写在Controller方法上或类上
作用:将方法返回值直接响应给浏览器
如果返回值类型是实体对象/集合,将会转换为JSON格式后在响应给浏览器
在我们前面所编写的controller方法中,都已经设置了响应数据。看一下类的注解@RestController, 这个注解是一个复合注解,里面包括了 @ResponseBody
结论:在类上添加@RestController就相当于添加了@ResponseBody注解。
类上有@RestController注解或@ResponseBody注解时:表示当前类下所有的方法返回值做为响应数据方法的返回值,如果是一个POJO对象或集合时,会先转换为JSON格式,在响应给浏览器
下面我们来测试下响应数据:
@RestController public class ResponseController { //响应字符串 @RequestMapping("/hello") public String hello(){ System.out.println("Hello World ~"); return "Hello World ~"; } //响应实体对象 @RequestMapping("/getAddr") public Address getAddr(){ Address addr = new Address();//创建实体类对象 addr.setProvince("广东"); addr.setCity("深圳"); return addr; } //响应集合数据 @RequestMapping("/listAddr") public List<Address> listAddr(){ List<Address> list = new ArrayList<>();//集合对象 Address addr = new Address(); addr.setProvince("广东"); addr.setCity("深圳"); Address addr2 = new Address(); addr2.setProvince("陕西"); addr2.setCity("西安"); list.add(addr); list.add(addr2); return list; } }
在服务响应了一个对象或者集合,那私前端获取到的数据是什么样子的呢?我们使用postman发送请求来测试下。测试效果如下:
可能大家会发现,我们在前面所编写的这些Controller方法中,返回值各种各样,没有任何的规范。
如果我们开发一个大型项目,项目中controller方法将成千上万,使用上述方式将造成整个项目难以维护。那在真实的项目开发中是什么样子的呢?
在真实的项目开发中,无论是哪种方法,我们都会定义一个统一的返回结果。方案如下:
这样前端只需要按照统一格式的返回结果进行解析(仅一种解析方案),就可以拿到数据。
统一的返回结果使用类来描述,在这个结果中包含:
响应状态码:当前请求是成功,还是失败
状态码信息:给页面的提示信息
返回的数据:给前端响应的数据(字符串、对象、集合)
定义在一个实体类Result来包含以上信息。代码如下:
public class Result { private Integer code;//响应码,1 代表成功; 0 代表失败 private String msg; //响应码 描述字符串 private Object data; //返回的数据 public Result() { } public Result(Integer code, String msg, Object data) { this.code = code; this.msg = msg; this.data = data; } public Integer getCode() { return code; } public void setCode(Integer code) { this.code = code; } public String getMsg() { return msg; } public void setMsg(String msg) { this.msg = msg; } public Object getData() { return data; } public void setData(Object data) { this.data = data; } //增删改 成功响应(不需要给前端返回数据) public static Result success(){ return new Result(1,"success",null); } //查询 成功响应(把查询结果做为返回数据响应给前端) public static Result success(Object data){ return new Result(1,"success",data); } //失败响应 public static Result error(String msg){ return new Result(0,msg,null); } }
改造后的Controller:统一返回Result
@RestController public class ResponseController { //响应统一格式的结果 @RequestMapping("/hello") public Result hello(){ System.out.println("Hello World ~"); //return new Result(1,"success","Hello World ~"); return Result.success("Hello World ~"); } //响应统一格式的结果 @RequestMapping("/getAddr") public Result getAddr(){ Address addr = new Address(); addr.setProvince("广东"); addr.setCity("深圳"); return Result.success(addr); } //响应统一格式的结果 @RequestMapping("/listAddr") public Result listAddr(){ List<Address> list = new ArrayList<>(); Address addr = new Address(); addr.setProvince("广东"); addr.setCity("深圳"); Address addr2 = new Address(); addr2.setProvince("陕西"); addr2.setCity("西安"); list.add(addr); list.add(addr2); return Result.success(list); } }
以上是SpringBoot取得前台參數的方式及統一回應的方法是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!