@Validated @Valid 正确使用姿势

@Valid

用于验证作为方法参数的请求体(@RequestBody)或模型属性(@ModelAttribute)的整体有效性。
放置在需要验证的请求体或模型属性参数前。
示例:

@PostMapping("/create")
public APIResult<BizCustomDto> create(@Valid @RequestBody BizCustomRequest request) {
    // ...
}

// 或者

@PostMapping("/update")
public APIResult<BizCustomDto> update(@Valid @ModelAttribute BizCustomDto dto) {
    // ...
}

@Validated

用于启用控制器类或方法级别的方法参数验证,包括基本类型、@RequestParam参数等。
放置在控制器类上以启用类级别验证,或放置在特定方法上以启用方法级别验证。
示例:

// 在控制器类级别启用方法参数验证
@Validated
@RestController
public class YourController {

    @GetMapping("/list")
    public APIResult<BizCustomDto> getCustomHeaderList(@NotNull(message = "服务id不能为空") @RequestParam("decisionId") Long decisionId) {
        return APIResult.success(dsServiceSearchBiz.getCustomHeaderList(decisionId));
    }

    // 其他方法...
}

// 或者仅在特定方法上启用方法参数验证
@RestController
public class YourController {

    @GetMapping("/list")
    @Validated
    public APIResult<BizCustomDto> getCustomHeaderList(@NotNull(message = "服务id不能为空") @RequestParam("decisionId") Long decisionId) {
        return APIResult.success(dsServiceSearchBiz.getCustomHeaderList(decisionId));
    }

    // 其他方法...
}

同时使用@Valid和@Validated:
当控制器类中既有需要对请求体或模型属性进行整体校验的方法,又有需要对方法参数进行独立验证的方法,可以在类级别使用@Validated,并在需要整体校验的方法的相应参数前添加@Valid注解。
示例:

@Validated
@RestController
public class YourController {

    @PostMapping("/create")
    public APIResult<BizCustomDto> create(@Valid @RequestBody BizCustomRequest request) {
        // ...
    }

    @GetMapping("/list")
    public APIResult<BizCustomDto> getCustomHeaderList(@NotNull(message = "服务id不能为空") @RequestParam("decisionId") Long decisionId) {
        return APIResult.success(dsServiceSearchBiz.getCustomHeaderList(decisionId));
    }

    // 其他方法...
}

综上所述,正确使用@Valid和@Validated的方式是根据实际需求,将它们放置在合适的位置,分别用于验证请求体/模型属性的整体有效性以及方法参数的独立有效性。同时,根据需要,可以在同一个控制器类中同时使用这两个注解,以覆盖不同的验证场景。

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值