前端传入BO验证

当前端传入一个json格式的数据,后端转换为一个Bean后,需要对Bean进行验证判断传入参数的合法性和有效性。

springboot工程中自动为我们引入了validation-api,我们直接使用即可。

import lombok.Data;
import org.hibernate.validator.constraints.Length;

import javax.validation.constraints.*;
import java.util.Date;

/**
 * @Author:waken
 * @Date: Created in 2020/1/4 14:32
 * @Description:
 */
@Data
public class UserBO {

    @NotBlank(message = "用户昵称不能为空")
    @Length(max = 12, message = "用户昵称不能超过12位")
    private String nickname;

    @Length(max = 12, message = "用户真实姓名不能超过12位")
    private String realname;

    @Pattern(regexp = "^(((13[0-9]{1})|(15[0-9]{1})|(18[0-9]{1}))+\\d{8})$", message = "手机号格式不正确")
    private String mobile;

    @Email
    private String email;

    @Min(value = 0, message = "性别选择不正确")
    @Max(value = 2, message = "性别选择不正确")
    private Integer sex;

}

接口层:

注意: @RequestBody @Valid UserBO   userBO,

            BindingResult result    必须要写,不然不做验证

/**
 * @Author:waken
 * @Date: Created in 2020/1/4 13:16
 * @Description:
 */
@RestController
@Api(tags = "用户接口")
@RequestMapping("userInfo")
public class CenterUserController extends BaseController {

    @PostMapping("/update")
    @ApiOperation(value = "修改用户信息", httpMethod = "POST")
    public ResultDTO update(
            @RequestBody @Valid UserBO userBO,BindingResult result) {
        ResultDTO resultDTO=new ResultDTO();
        if (result.hasErrors()) {
            Map<String, String> errors = getErrors(result);
            return resultDTO.errorMap(errors);
        }
        return null;
    }
}

BaseController:

/**
 * @Author:waken
 * @Date: Created in 2019/12/27 10:59
 * @Description:
 */
public class BaseController {

    public Map<String, String> getErrors(BindingResult result) {
        Map<String, String> map = new HashMap<>();
        List<FieldError> errorList = result.getFieldErrors();
        for (FieldError error : errorList) {
            String errorField = error.getField();
            String errorMsg = error.getDefaultMessage();
            map.put(errorField, errorMsg);
        }
        return map;
    }

}

常用验证注解:

* @Null 被注释的元素必须为 null
* @NotNull 被注释的元素必须不为 null
* @AssertTrue 被注释的元素必须为 true
* @AssertFalse 被注释的元素必须为 false
* @Min(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
* @Max(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
* @DecimalMin(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
* @DecimalMax(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
* @Size(max=, min=) 被注释的元素的大小必须在指定的范围内
* @Digits (integer, fraction) 被注释的元素必须是一个数字,其值必须在可接受的范围内
* @Past 被注释的元素必须是一个过去的日期
* @Future 被注释的元素必须是一个将来的日期
* @Pattern(regex=,flag=) 被注释的元素必须符合指定的正则表达式
* @NotBlank(message =) 验证字符串非null,且长度必须大于0
* @Email 被注释的元素必须是电子邮箱地址
* @Length(min=,max=) 被注释的字符串的大小必须在指定的范围内
* @NotEmpty 被注释的字符串的必须非空
* @Range(min=,max=,message=) 被注释的元素必须
 
 
如果看过对你有帮助,麻烦点个收藏谢谢!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值