• @RequestBody、 @RequestParam 、 @PathVariable 和 @Vaild 注解


    后端接收前端传的参数主要有两种方式:

            第一种:

                       用变量来接收,前端传递的参数会对相同变量名进行赋值.

                       第(1)种:

    1. @GetMapping("/info/{id}")
    2. public ApiResult> testModel(@PathVariable("id") Long id) {
    3. //方法体
    4. }

                       第(2)种: 

                            @RequestParam()指定的参数可以是普通元素、 数组、集合等等.

    1. @PostMapping("/info")
    2. public ApiResult<List<Test>> testModel(@RequestParam(value = "areaId", required = false) String areaId) {
    3. //方法体
    4. }

            第二种:

                       用对象来接收,前端传递的参数会对对象里面的相同属性名进行赋值.

                       如若对象是集合和数组等等,则会对相同对象名进行赋值,或者也可以对相同变量名进行                     赋值.

    1. @PostMapping("/pageList")
    2. public ApiResult<List<Student>> testModel(@Valid @RequestBody Student student) {
    3. //方法体
    4. }

     注解详解:

    @RequestBody

    @RequestBody 主要用来接收前端传递给后端的 json 字符串中的数据(请求体中的数据);

    Get 方式无请求体,所以使用 @RequestBody 接收数据时,前端不能使用 Get 方式提交数据;
    而是使用 Post 方式进行提交的。在后端的同一个接收方法里,@RequestBody 与 @RequestParam() 可以同时使用; @RequestBody 最多只能有一个,而 @RequestParam() 可以有多个。

    • 注:一个请求,只有一个 RequestBody;一个请求,可以有多个 RequestParam。

    1. 注:当同时使用 @RequestParam()和 @RequestBody时:
    2. @RequestParam()指定的参数可以是普通元素、 数组、集合、对象等等
    3. (即当:@RequestBody@RequestParam() 可以同时使用时,原 SpringMVC 接收参数的机制不变,
    4. 只不过 RequestBody 接收的是请求体里面的数据;
    5. 而 RequestParam 接收的是 key-value 里面的参数,所以它会被切面进行处理从而可以用普通元素、
    6. 数组、集合、对象等接收)
    7. 即:如果参数时放在请求体中,传入后台的话,那么后台要用 @RequestBody 才能接收到;如果不是放
    8. 在请求体中的话,那么后台接收前台传过来的参数时,要用 @RequestParam 来接收,或则形参前什么
    9. 也不写也能接收。
    1. 注:如果参数前写了 @RequestParam(xxx),那么前端必须有对应的 xxx 名字才行
    2. (不管其是否有值,当然可以通过设置该注解的 required 属性来调节是否必须传)
    3. 如果没有 xxx 名的话,那么请求会出错,报400
    1. 注:如果参数前不写 @RequestParam(xxx) 的话,那么就前端可以有可以没有对应的 xxx 名字才行,
    2. 如果有 xxx 名的话,那么就会自动匹配;没有的话,请求也能正确发送。

    @RequestParam

    @RequestParam 用于将请求参数区域的数据映射到控制层功能处理方法的参数上

    • 主要参数语法:

      @RequestParam(value=“参数名”, required=“true/false”, defaultValue="")

     1、value:请求中传入参数的名称,如果不设置后台接口的 value 值,则会默认为该变量名。如下图中第一个参数如果不设置 value=“pageNum” ,则前端传入的参数名必须为 pageNum ,否则在后台接口中 pageNum 将接收不到对应的数据。

    2、required:是否包含该参数,默认为 true,表示该请求路径中必须包含该参数,如果不包含就报404等错误。如果设置为 false 时,当请求中没有此参数,将会默认为 null,而对于基本数据类型的变量,则必须有值,这时会抛出空指针异常。如果允许空值,则接口中变量需要使用包装类来声明。 

    3、defaultValue:默认参数值,如果设置了该值,required=true 将失效,自动为 false,如果没有传该参数,就使用默认值。 

    故屿

    @PathVariable

    接收请求路径中占位符的值,
    @PathVariable 注解可以将 URL 中占位符参数绑定到控制器处理方法的入参中;URL 中的 {xxx} 占位符可以通过 @PathVariable(“xxx“) 绑定到操作方法的入参中。
    如下图示:

    故屿

    @Valid 

    @Valid 注解可以实现数据的验证,可以先定义实体,在实体的属性上添加校验规则,而在 Api 接收数据
    时添加 @valid 关键字,这时定义的实体将会开启一个校验的功能。

    @Valid 注解用于校验时所属包为:javax.validation.Valid。 

    • 首先需要在实体类的相应字段上添加用于充当校验条件的注解,如下图示:

     故屿

    • 其次在 controller 层的方法校验的参数上添加 @Valid 注解,并且需要传入 Dto 实体类对象,用于校验获取相应字段上添加的 message 中的内容,如下图示:

    在这里插入图片描述

    • 注:不要错用了异常类型,比如在 int 上不可用 @size

    ----------- @区别对比 ----------- 

    @RequestBody注解和 @RequestParam 注解的区别

    在 Get 请求中,不能使用 @RequestBody。 在 Post 请求,可以使用 @RequestBody 和 @RequestParam,但是如果使用 @RequestBody,对于参数转化的配置必须统一。

    @RequestParam 注解接收的参数是来自于 requestHeader 中,即请求头。都是用来获取请求路径 url 中的动态参数。也就是在 url 中,格式为 xxx?username=123&password=456。
    @RequestBody 注解接收的参数则是来自于 requestBody 中,即请求体中。 

    @RequestParam 注解和 @PathVariable 注解的区别 

    @RequestParam 和 @PathVariable 注解是用于从 request 中接收请求的,两个都可以接收参数,关键点不同的是 @RequestParam 是从 request 里面拿取值,而 @PathVariable 是从一个 url 模板里面来填充。 

    @RequestParam 注解是获取静态 url 传入的参数
    @PathVariable 是获取请求路径中的变量作为参数,需要和 @RequestMapping(“item/{itemId}”) 配合使用。 

    ----------- @验证信息表 ----------- 

    验证信息的说明表 

  • 相关阅读:
    2022年值得关注的5个区块链项目 数字藏品平台开发搭建
    Stream学习2
    力扣题库2. 两数相加
    Three.js如何计算3DObject的2D包围框?
    【单片机毕业设计选题24009】-基于单片机的智能窗帘控制系统设计
    开源ide 类idea 风格
    麦芽糖-刀豆球蛋白A,maltose-ConcanavalinA,刀豆球蛋白A-PEG-麦芽糖
    【zlmediakit】uint32的rtp时间戳和uint64的毫秒时间戳互转
    比较两个文本,找出在另一文本中出现过的串并换某种格式输出
    Qt的信号和槽机制
  • 原文地址:https://blog.csdn.net/qq_58148854/article/details/126002458