接口入参验证(@RequestParam\@Valid\@Validated\@RequestBody)

本文深入解析了@RequestParam与@RequestBody在不同请求类型中的应用,详细介绍了如何使用@Valid和@Validated进行参数有效性检查,包括基本类型及实体对象的验证,并探讨了嵌套对象的验证策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天了解了下接口入参验证问题:

1.

@RequestParam   适用于Get请求且content-type为application/x-www-form-urlencoded

@RequestBody     适用于post请求且content-type为application/x-www-form-urlencoded类型,一般为application/json

 

2.

(1)入参为@RequestParam或@RequestBody时,不用加@valid和@validated;

(2)入参为@NotNull时要在方法上加@valid或@validated,或者在类上加@Validated(@valid不能作用于类上),这样@NotNull才能起作用。

@Valid
@GetMapping("/exam-info")
public Boolean getInfo(@NotNull(message="examId不能为空")Long examId){......}

(3)当入参为实体对象时,需要在方法上加@Valid或@Validated或者在参数前加@Valid或@Validated,或者在类上加@Validated

@Valid
@GetMapping("/exam-info")
public Boolean getInfo(User user){......}


@GetMapping("/exam-info")
public Boolean getInfo(@Valid User user){......}

@Validated
@GetMapping("/exam-info")
public Boolean getInfo(User user){......}


@GetMapping("/exam-info")
public Boolean getInfo(@Validated User user){......}

public Class User{

    @NotNull("id不能为空")
    private Integer id;
    .
    .
    .
}

4.嵌套验证

     @valid作用于属性上有嵌套验证作用,@validated不能作用于属性上,如下代码在User类的属性car上添加@valid注解,当传参id为空时会报错。

@GetMapping("/exam-info")
public Boolean getInfo(@Valid User user){.....}

@GetMapping("/exam-info")
public Boolean getInfo(@Validated User user){.....}

public class User{
  @Valid
  @NotNull("car不能为空")
  private Car car;

  ........

}

public class Car{
  
  @NotNull("id不能为空")
  private Integer id;

  ........

}

 

package com.priusis.report.controller; import com.priusis.api.domain.monitor.TrainIo; import com.priusis.api.domain.monitor.TrainIu; import com.priusis.api.domain.monitor.TrainNet; import com.priusis.core.common.lib.Result; import com.priusis.report.service.IDoorStatusService; import org.springframework.format.annotation.DateTimeFormat; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import javax.annotation.Resource; import javax.validation.constraints.NotNull; import java.util.Date; import java.util.List; import java.util.Map; /** * @author yangli * @since 2021/07/01 */ @Validated @RestController @RequestMapping(value = "door_status") public class DoorStatusController { @Resource private IDoorStatusService doorStatusService; // @GetMapping(value = "io/list") public Result<List<TrainIo>> ioList( @RequestParam @NotNull Integer trainNo, @RequestParam @NotNull Integer carriageNo, @RequestParam @NotNull Integer doorNo, @RequestParam(value = "hour") @NotNull @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm") Date minute) { return Result.success(doorStatusService.ioList(trainNo, carriageNo, doorNo, minute)); } @GetMapping(value = "net/list") public Result<List<TrainNet>> netList( @RequestParam @NotNull Integer trainNo, @RequestParam @NotNull Integer carriageNo, @RequestParam @NotNull Integer doorNo, @RequestParam(value = "hour") @NotNull @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm") Date minute) { return Result.success(doorStatusService.netList(trainNo, carriageNo, doorNo, minute)); } 帮我解释一下
03-11
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值