SpringBoot中使用@Valid 做入参表单校验 以及常见校验规则

1.在pom.xml中引入 hibernate-validator

    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-validator</artifactId>
        <version>6.0.13.Final</version>
    </dependency>

2.注入bean:

@Configuration
public class FactoryConfig {
    @Bean
    public MethodValidationPostProcessor methodValidationPostProcessor() {
        return new MethodValidationPostProcessor();
    }
}

3.在需要参数校验的Controller添加校验注解

@ApiOperation(value = "登录")
@PostMapping(value = "/login")
public ResponseMessage loginRest(@Valid @RequestBody LoginInfoVO loginInfoVO, HttpServletRequest request) {
   try {
       logger.info(JSON.toJSONString(loginInfoVO));

       UserDetailVO userDetailVO = userInfoService.getUserByUserName(loginInfoVO, request);
       if (null == userDetailVO) {
           throw new TokenAccessException(ResponseEnum.QUERY_FAILED.getCode(), ResponseEnum.QUERY_FAILED.getMessage());
       }
   } catch (Exception e) {
       logger.error("登录失败", e);
       return Result.success(ResponseEnum.ERROR.getCode(), "登录失败", null);
   }
}

4.在bean中添加校验规则

package com.adc.da.entity.precise.vo;

import lombok.Data;
import javax.validation.constraints.NotBlank;
import javax.validation.constraints.NotNull;

@Data
public class LoginInfoVO {

    @NotBlank(message = "用户名不能为空")
    private String username;
    
    @NotBlank(message = "密码不能为空")
    private String password;

    @NotBlank(message = "验证码不能为空")
    private String verifyCode;

    @NotBlank(message = "sessionId不能为空")
    private String sessionId;

}

5.添加统一的异常处理方法

@ControllerAdvice
@Order(value = 0)
public class MethodArgumentNotValid {
    @ResponseBody
    @ExceptionHandler(MethodArgumentNotValidException.class)
    public ResponseMessage defultExcepitonHandler(MethodArgumentNotValidException exception) throws Exception {
        logger.error(exception.getMessage(), exception);
        
        List<ValidErrorVO> validErrorList = new ArrayList<>();
        BindingResult result = exception.getBindingResult();
        for (FieldError fieldError : result.getFieldErrors()) {
            validErrorList.add(new ValidErrorVO(fieldError.getField(), fieldError.getDefaultMessage()));
            logger.warn("valid error: obj[{}], filed[{}], message[{}]", fieldError.getObjectName(), fieldError.getField(), fieldError.getDefaultMessage());
        }
        ErrorBackVO errorBackVO = new ErrorBackVO(validErrorList);
        Map<String, ErrorBackVO> map = new HashMap<>();
        map.put("ErrorBackVO", errorBackVO);
        //返回错误信息
        return Result.error(ResponseEnum.SCAN_VALID_FAILED.getCode(), ResponseEnum.SCAN_VALID_FAILED.getMessage(), map);
    }
}
6.测试

在登录接口入参中删除 verifyCode

1.入参:

{
  "password": "string",
  "sessionId": "string",
  "username": "string"
}

2.响应数据:

{
  "respCode": "4005",
  "data": {
    "ErrorBackVO": {
      "validErrorVOList": [
        {
          "file": "verifyCode",
          "message": "验证码不能为空"
        }
      ]
    }
  },
  "ok": false,
  "message": "数据校验失败"
}

校验拦截成功

附:常见校验规则

@Null       验证对象是否为null
@NotNull    验证对象是否不为null, 无法查检长度为0的字符串
@NotBlank 检查约束字符串是不是Null还有被Trim的长度是否大于0,只对字符串,且会去掉前后空格.
@NotEmpty 检查约束元素是否为NULL或者是EMPTY.
@CreditCardNumber信用卡验证
@Email  验证是否是邮件地址,如果为null,不进行验证,算通过验证。
@URL(protocol=,host=, port=,regexp=, flags=) ip地址校验

Booelan检查
@AssertTrue     验证 Boolean 对象是否为 true  
@AssertFalse    验证 Boolean 对象是否为 false  

长度检查
@Size(min=, max=)   验证对象(Array,Collection,Map,String)长度是否在给定的范围之内  
@Length(min=, max=) Validates that the annotated string is between min and max included.
 
日期检查
@Past       验证 Date 和 Calendar 对象是否在当前时间之前  
@Future     验证 Date 和 Calendar 对象是否在当前时间之后  
@Pattern    验证 String 对象是否符合正则表达式的规则

数值检查,建议使用在Stirng,Integer类型,不建议使用在int类型上,因为表单值为""时无法转换为int,但可以转换为Stirng为"",Integer为null
@Min            验证 Number 和 String 对象是否大等于指定的值  
@Max            验证 Number 和 String 对象是否小等于指定的值  
@DecimalMax     被标注的值必须不大于约束中指定的最大值. 这个约束的参数是一个通过BigDecimal定义的最大值的字符串表示.小数存在精度
@DecimalMin     被标注的值必须不小于约束中指定的最小值. 这个约束的参数是一个通过BigDecimal定义的最小值的字符串表示.小数存在精度
@Digits         验证 Number 和 String 的构成是否合法  
@Digits(integer=,fraction=) 验证字符串是否是符合指定格式的数字,interger指定整数精度,fraction指定小数精度。
@Range(min=, max=) Checks whether the annotated value lies between (inclusive) the specified minimum and maximum





更多好玩好看的内容,欢迎到我的博客交流,共同进步        WaterMin

喜欢听相声的朋友,也可以来我的 YouTube,来听郭老师的相声    秋酿


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用 elementui 表单校验来对表格的每行输入框进行校验。 首先,在表格定义每行输入框时,需要使用 `el-form-item` 组件包裹每个输入框,并设置 `prop` 属性,用于在校验时区分不同的输入框。 例如: ``` <el-table> <el-table-column prop="name" label="名称"> <template slot-scope="scope"> <el-form-item prop="name"> <el-input v-model="scope.row.name"></el-input> </el-form-item> </template> </el-table-column> <el-table-column prop="age" label="年龄"> <template slot-scope="scope"> <el-form-item prop="age"> <el-input v-model="scope.row.age"></el-input> </el-form-item> </template> </el-table-column> </el-table> ``` 然后,在表单添加 `el-form` 组件,并设置 `ref` 属性,用于在代码获取表单对象。同时,还需要为每个输入框设置校验规则,并在表单校验时调用校验方法。 例如: ``` <el-form ref="form" :model="formData" :rules="formRules"> <el-table> ... </el-table> </el-form> ``` ``` data() { return { formData: [ { name: '张三', age: 18 }, { name: '李四', age: 20 } ], formRules: { name: [ { required: true, message: '请输入名称', trigger: 'blur' } ], age: [ { required: true, message: '请输入年龄', trigger: 'blur' }, { type: 'number', message: '年龄必须为数字', trigger: 'blur' } ] } } }, methods: { validateForm() { this.$refs.form.validate(valid => { if (valid) { // 校验通过,提交表单 } else { // 校验失败,提示错误信息 } }) } } ``` 在上面的代码,`formData` 数组包含了表格每行的数据,`formRules` 对象定义了每个输入框的校验规则。在 `validateForm` 方法,调用了表单校验方法 `validate`,并在回调函数根据校验结果进行处理。 需要注意的是,由于表格的每行输入框是动态生成的,因此需要在每次表格数据发生变化时重新设置校验规则,可以在 `watch` 监听数据变化,然后调用 `resetFields` 方法重置表单,再设置新的校验规则。 例如: ``` watch: { formData: { deep: true, handler() { this.$nextTick(() => { this.$refs.form.resetFields() this.$refs.form.clearValidate() this.setRules() }) } } }, methods: { setRules() { const rules = {} this.formData.forEach((item, index) => { rules[`name.${index}`] = [ { required: true, message: '请输入名称', trigger: 'blur' } ] rules[`age.${index}`] = [ { required: true, message: '请输入年龄', trigger: 'blur' }, { type: 'number', message: '年龄必须为数字', trigger: 'blur' } ] }) this.formRules = rules } } ``` 在上面的代码,`setRules` 方法根据表格数据动态生成校验规则,然后通过 `this.formRules = rules` 将校验规则设置到表单。在 `watch` 监听 `formData` 变化时,调用 `this.setRules()` 方法重新设置校验规则。同时,调用 `this.$refs.form.resetFields()` 方法重置表单,以清除之前的校验状态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值