ホームページ >Java >&#&チュートリアル >SpringBoot はフロントエンドのパラメーターをどのように取得し、均一に応答するのか?
SpringBoot がフロントエンド パラメーターを受け入れる 6 つの方法 まず第一に、インターフェイスなしでフロントエンドから送信されるリクエストはアドレス バーからのみ送信でき、Get のみが可能であるためです。 request, 他のリクエストをテストするために、ツール -> Postman を使用します。Postman は、Web ページをデバッグし、Web ページに HTTP リクエストを送信するための強力な Chrome プラグインです。
フロントから渡されるパラメータは大きく6種類に分かれます。デモをして一つずつ勉強しましょう。デモの前に復習してください。フロントパラメータはSpringBoot経由で取得する方法はなく、これらはリクエスト オブジェクトを通じて取得されます。
@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)、これはリクエスト パラメータを渡す必要があることを意味します。渡されない場合、エラーが報告されます。パラメータがオプションの場合、必須属性を 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"; }
単純なエンティティ オブジェクト:
データ送信方法として単純なパラメータを使用する場合、フロントエンドによって渡されるリクエスト パラメータの数と、バックエンド コントローラー メソッドに書き込む仮パラメーターの数。リクエストパラメータが多い場合、上記の方法でパラメータを一つ一つ受け取るのは煩雑になります。
この時点で、リクエスト パラメーターをエンティティ クラス オブジェクトにカプセル化することを検討できます。データのカプセル化を完了するには、次の規則に従う必要があります。 リクエスト パラメータ名はエンティティ クラスの属性名と同じです
要件は、パラメータがエンティティ クラスから渡されることです。フロントデスクは、オブジェクト内のパラメータと同じ名前を持つ必要があります。
@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 に別のフィールドがあり、このクラスには 2 つのプロパティがあります。このとき、パラメータを に渡す必要があります。変更しますが、バックグラウンドは引き続きユーザーを使用して
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
バックエンド プログラムが上記の複数の値を受け取るには 2 つの方法があります:
Array
コレクション
配列パラメータ: リクエストパラメータ名は仮パラメータグループ名と同じであり、リクエストパラメータは複数存在します。配列型仮パラメータを定義するだけです 受信パラメータ
@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"; } }
をバインドする必要があります。上記のデモはすべて共通です。一部の特殊な要件では、パラメーターに日付型データのカプセル化が含まれる場合があります (実際、通常は文字列を保存し、転送しないため、ここで理解します)。たとえば、次の要件があります。
日付の形式がさまざまであるため (例: 2022-12-12 10:05:45、2022/12/12 10: 05:45)、日付型パラメータをカプセル化する場合、@DateTimeFormat アノテーションとそのパターン属性を通じて日付形式を設定する必要があります。
#@DateTimeFormat アノテーション、パターン属性で日付形式が指定されている場合、フロントエンドの日付パラメータは指定された形式で渡す必要があります。
バックエンド コントローラー メソッドでは、Date 型 LocalDateT または LocalDateTime 型を使用して、渡されたパラメーターをカプセル化する必要があります。
コントローラー メソッド:
@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"; } }
フロントエンド テクノロジを学ぶときに、JSON について話しました。エンドとバックエンド インタラクション中、パラメーターがより複雑な場合、フロントエンドとバックエンドは送信に JSON 形式のデータを使用します。 (JSON は、開発において最も一般的に使用されるフロントエンドとバックエンドのデータ対話方法です。)実際、バックエンドがフロントエンドにデータを返す場合、一部は文字列、一部はコレクション、一部は JSON であることもわかります。 , その後、フロントエンドがそれを解析します。これは非常に面倒です。その後、エンティティ クラスを使用してすべてのデータを保存し、オブジェクトを返します。この方法では、フロント デスクは JSON を受け取るときにのみ処理する必要があります。メモの最後に、
について触れます。これについては、以下の「Postman How to send JSON data:
」で紹介されています。服务端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 中国語 Web サイトの他の関連記事を参照してください。