@Valid进行参数检验

  1. 在model对象中,需要进行参数校验的属性加上注解
 public class Admin extends User {
    private String openId;//openId

    @NotEmpty(message = "员工账号不能为空")
    private String id;//账号
    @NotEmpty(message = "员工姓名不能为空")
    private String name;//姓名
    @NotEmpty(message = "员工部门不能为空")
    private String apartment;//部门

    private String team;//班组
    private String position;//职位

    @Pattern(regexp = "^(13[0-9]|14[0-9]|15[0-9]|18[0-9]|17[0-9])\\d{8}$", message = "手机格式错误")
    private String mobilePhone;//移动电话
    private String landline;//座机

    @Email(message = "邮箱格式错误")
    private String intranetMailbox;//内网邮箱
    @Email(message = "邮箱格式错误")
    private String extranetMailbox;//外网邮箱
}
    

常用的Valid注解

@Null	限制只能为null

@NotNull	限制必须不为null

@AssertFalse	限制必须为false

@AssertTrue	限制必须为true

@DecimalMax(value)	限制必须为一个不大于指定值的数字

@DecimalMin(value)	限制必须为一个不小于指定值的数字

@Digits(integer,fraction)	限制必须为一个小数,且整数部分的位数不能超过integer,小数部分的位数不能超过fraction

@Future	限制必须是一个将来的日期

@Max(value)	限制必须为一个不大于指定值的数字

@Min(value)	限制必须为一个不小于指定值的数字

@Past	限制必须是一个过去的日期

@Pattern(value)	限制必须符合指定的正则表达式

@Size(max,min)	限制字符长度必须在min到max之间

@Past	验证注解的元素值(日期类型)比当前时间早

@NotEmpty	验证注解的元素值不为null且不为空(字符串长度不为0、集合大小不为0)

@NotBlank	验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格

@Email	验证注解的元素值是Email,也可以通过正则表达式和flag指定自定义的email`

  1. Controller层
 /**
     * 新增员工
     * 员工账号,名称, 部门不能为空
     * @param admin
     * @return
     */
    @PostMapping("/insertWXAdmin")
    public JSONObject insertWXAdmin(@Valid  @RequestBody Admin admin){
        System.out.println(admin);
        return adminService.insertWXAdmin(admin);
    }

3.全局异常捕获


    /**
     * 参数异常检验
     * @param ex
     * @return
     */
    @ExceptionHandler(MethodArgumentNotValidException.class)
    public JSONObject  methodArgumentNotValidException(MethodArgumentNotValidException ex) {
        LOGGER.error("raised MethodArgumentNotValidException : " + ex);
        BindingResult result = ex.getBindingResult();
        final List<FieldError> fieldErrors = result.getFieldErrors();
        StringBuilder builder = new StringBuilder();

        for (FieldError error : fieldErrors) {
            builder.append( error.getDefaultMessage()+",");
        }
        return ResultUtil.returnJSONObject(400, builder.toString(), null);
    }
  1. 使用Postman进行测试

请求内容

{
	"id": "",
	"name": "",
	"apartment": "",
	"team": "",
	"position": "班员",
	"mobilePhone": "15923",
	"landline":"",
	"intranetMailbox": "",
	"extranetMailbox":"ranjun1999p163.com",
	"remark":"无",
	"openId": "",
	"role": "管理员",
	"major": "业扩",
	"password":"123"
}

返回结果

{
    "code": 400,
    "data": null,
    "message": "手机格式错误,邮箱格式错误,员工部门不能为空,员工姓名不能为空,员工账号不能为空,"
}
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
@Validated是Spring框架中的一个注解,用于对方法的参数进行验证。它可以用于类、方法和方法参数上。@Valid是Java标准(javax.validation)中的一个注解,也用于对方法参数进行验证。 这两个注解在基本验证功能上没有太多区别,都可以用来验证参数是否符合规范。但在其他功能上有所不同。 @Validated注解可以使用分组、注解地方、嵌套验证等功能,而@Valid注解则没有这些功能。 @Validated注解的@Target包括ElementType.TYPE、ElementType.METHOD和ElementType.PARAMETER等,而@Valid注解的@Target只包括ElementType.PARAMETER。 在Spring框架中,我们可以使用@Validated注解来替代手动对参数进行校验,这样可以简化代码并提高代码的可读性。同时,@Validated注解还提供了更多的验证功能,可以根据需要进行灵活的配置。 总之,@Validated和@Valid都是参数检验工具,但在功能上有一些区别。具体使用哪个注解取决于项目的需求和框架的要求。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [@Validated、@Valid对比及详细用法](https://blog.csdn.net/liuerchong/article/details/123041734)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值