我是靠谱客的博主 暴躁蓝天,最近开发中收集的这篇文章主要介绍使用validation校验BigDecimal,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

使用validation校验实体类中的字段

在新增的时候,controller层接口使用@RequestBody接收前端传过来的参数,针对body中的参数,使用validation进行校验,本篇记录使用validation校验BigDecimal格式的字段。

实体类

/**
 * @author kozo
 * @date 2021/4/13 22:53
 */
@Data
public class BigDecimalValidationEntity {

    /**
     * 这里amount类型是BigDecimal, @Digits, @DecimalMin也是针对数值的校验
     * 但是使用字符串传值,校验也能生效,只要字符串里面是数字就行
     */
    @Digits(integer = 9, fraction=2, message = "amount格式不正确")
    @DecimalMin(value = "0.00", message = "amount格式不正确")
    @NotNull(message = "amount不为空")
    private BigDecimal amount;
}

接口

    @PostMapping("decimalTest")
    public String decimalTest(@RequestBody @Validated BigDecimalValidationEntity entity) {
        System.out.println(entity.getAmount());
        return String.valueOf(entity.getAmount());
    }

统一异常处理

这里只是简单的返回注解中的字符串信息,在具体的业务中可以把这里的getDefaultMessage()获取的信息放到具体的包装中返回。

@ControllerAdvice
@ResponseBody
public class MyExceptionHandler {

    @ExceptionHandler(value = MethodArgumentNotValidException.class)
    public String methodArgumentNotValidExceptionHandler(MethodArgumentNotValidException e) {
        return e.getBindingResult().getFieldError().getDefaultMessage();
    }
}

注解说明

  • @Digits(integer = 9, fraction=2, message = "amount格式不正确")
    

    digit是数位的意思,这里的integer意思整数最多有几位,fraction意思小数最多有几位,只是划定了传入参数的范围,前端传值的时候可以用字符串(只要字符串里面都是数字就行)、数字;

  • @DecimalMin(value = "0.00", message = "amount格式不正确")
    

    decimal的最小值,传入参数必须大于等于value里面的值;

  • @NotNull(message = "amount不为空")
    

    传入参数不为空,对于BigDecimal格式,用@NotNull注解,如果传参是空字符串或者只有空格的字符串,也无法通过校验。

  • ps:如果字段的类型是String,建议使用@NotBlank注解。

一些测试验证(可以不用看了)

image-20210414101611557

image-20210414101630713

image-20210414101651646

image-20210414101719299

image-20210414101753468

image-20210414101814597

image-20210414101832004

最后

以上就是暴躁蓝天为你收集整理的使用validation校验BigDecimal的全部内容,希望文章能够帮你解决使用validation校验BigDecimal所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(56)

评论列表共有 0 条评论

立即
投稿
返回
顶部