Hibernate-Validator(参数的校验)

一、Validator 有什么作用?

  1. 在开发中经常需要写一些字段校验的代码,比如字段非空,字段长度限制,邮箱格式验证等等

  2. 防止攻击!我们前后端分离,我们后端仅仅提供数据接口,若有人想破解我们,别人可以直接跳过前端!

1.1 场景

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fuBgCPwP-1585211332526)(assets/wps1.jpg)]

上图验证,只是前端的验证。对后端来说会增加数据的规范性,但是别人可以跳过你这个前端的验证!

使用Postman 就可以跳过前端验证。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rfRgDtPc-1585211332528)(assets/wps2.jpg)]

所以我们需要在后端做一个数据的验证

1.2 validate的使用

  1. 添加 Hibernate-Validator 依赖。
<dependency>
   <groupId>org.hibernate</groupId>
   <artifactId>hibernate-validator</artifactId>
   <version>6.0.7.Final</version>
</dependency>
  1. 在类的属性上加上对应的注解,set,get方法采用了lombok框架,@apiModelProperty是swagger2依赖的注解

**注意:**这个地方的@NotBlank等验证注解一定要是以上依赖中提供的。否则可能出现问题。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-X5bbOYNJ-1585211332529)(assets/1583074724197.png)]

  1. 在后端post方法上添加@RequestBody 和@Valid注解

只有添加@Valid注解,在类上书写的注解才可以生效。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-59k95PiY-1585211332530)(assets/1583074809065.png)]

  1. 校验validator注解是否生效

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lvkM2dGV-1585211332531)(assets/1583075011092.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YrEK0J7F-1585211332532)(assets/1583074953294.png)]

由上图可知,校验注解生效,但是会抛出一个异常。所以应该对这个异常进行处理
注意:
1、此时可能会由于一些依赖冲突的原因会导致上述错误消息没有出现,可以到控制台中查看错误消息。
2、不同类型对应的validator注解不能混用,否则可能会报错

1.3 validator常用的注解

注解释义
@NotNull被注释的元素必须不为 null 元素可以为任意值
@NotBlank被标记的字符串不能为null或空串 只能标记在字符串上
@NotEmpty被标记的集合不能为null或空集合 只能标记在集合上
@Null被注释的元素必须为 null
@AssertTrue被注释的元素必须为true
@AssertFalse被注释的元素必须为 false
@Min(value)被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@Max(value)被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@DecimalMin(value)被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@Size(max, min)被注释的元素的大小必须在指定的范围内,元素必须为集合,代表集合个数
@Digits (integer, fraction)被注释的元素必须是一个数字,其值必须在可接受的范围内
@Past被注释的元素必须是一个过去的日期
@Future被注释的元素必须是一个将来的日期
@Email被注释的元素必须是电子邮箱地址
@Length(min=, max=)被注释的字符串的大小必须在指定的范围内,必须为数组或者字符串,若为数组则表示为数组长度,字符串则表示为字符串长度
@Range(min=, max=)被注释的元素必须在合适的范围内
@Pattern(regexp = )正则表达式校验
@Valid对象级联校验,即校验对象中对象的属性

二、全局的异常处理

package com.zxm.aspect;

import lombok.extern.slf4j.Slf4j;
import org.apache.shiro.authc.AuthenticationException;
import org.apache.shiro.authz.UnauthorizedException;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.RestControllerAdvice;

@Slf4j  // 记录日志的注解   相当于private static final Logger log  = LoggerFactory.getLogger(WebLogError.class);
@RestControllerAdvice // 用户拦截Controller抛给用户的异常信息
public class WebLogError {
    /**
     * 代表用户登录可能过期了
     */
    @ExceptionHandler(AuthenticationException.class)
    public ResponseEntity<String> authException(){
        return ResponseEntity.status(HttpStatus.UNAUTHORIZED).body("你的登录已经过期,请重新登录");
    }
    /**
     * 参数异常:需要给别人提醒一下
     */
    @ExceptionHandler(IllegalArgumentException.class)
    public ResponseEntity<String> paramException(IllegalArgumentException e){
        return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(e.getMessage());
    }

    /**
     *  若是运行时,异常,我们的错误信息不能随便泄露给别人
     * @param e
     * @return
     */
    @ExceptionHandler(RuntimeException.class)
    public ResponseEntity<String> runtimeException(RuntimeException e){
        log.error("运行异常",e); // 可以帮我们记录在日志文件里面。方便排错
        return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("服务器正在维修");
    }

    /**
     * shiro 里面没有某种权限的异常
     * @return
     */
    @ExceptionHandler(UnauthorizedException.class)
    public ResponseEntity<String> unauthorized(){
        return ResponseEntity.status(HttpStatus.UNAUTHORIZED).body("没有权限访问") ;
    }
    
    /**
     * shiro 里面没有某种权限的异常
     * @return
     */
	@ExceptionHandler(MethodArgumentNotValidException.class)
    public ResponseEntity<String> methodArgumentNotValidException(MethodArgumentNotValidException bindException){
        BindingResult bindingResult = bindException.getBindingResult();// bindingResult就是验证错误的结果
        System.out.println(bindingResult);
        StringBuffer sb = new StringBuffer("数据校验失败,原因是:");
        List<FieldError> fieldErrors = bindingResult.getFieldErrors();
        for (FieldError fieldError : fieldErrors) {
            /**
             * fieldError.getField 那个字段
             * fieldError.getDefaultMessage 错误原因
             */

            sb.append(fieldError.getDefaultMessage()+"!");
        }
        return ResponseEntity.badRequest().body(sb.toString());
    }

}
### 回答1: Hibernate Validator是一个用于Java Bean验证的框架,它提供了一组注解和API,用于验证Java Bean的属性值是否符合指定的规则和约束。它可以用于验证表单数据、REST API请求、数据库实体等各种场景下的数据。Hibernate Validator支持多种验证规则,包括基本数据类型、字符串、日期、集合、数组等。它还支持自定义验证规则和错误消息。使用Hibernate Validator可以有效地减少代码量和提高开发效率。 ### 回答2: Hibernate Validator是一个流行的Java开源校验框架,它是基于JSR 303规范(Bean验证)的实现。它提供了一组注释和API,用于对JavaBean进行验证和校验Hibernate Validator提供了很多内置的校验注释,比如@NotNull、@NotEmpty、@Min、@Max等。这些注释可以直接应用在JavaBean的属性上,通过注释指定的校验规则来验证属性的值是否合法。同时,Hibernate Validator还支持自定义校验注释,可以根据业务需求来定义新的注释,并实现相应的校验逻辑。 Hibernate Validator不仅可以对单个属性进行校验,还支持对整个JavaBean进行校验。例如,可以在JavaBean的类级别上添加@Valid注释,来验证整个对象的合法性。此外,还可以通过分组校验来实现在不同场景下不同的校验规则。 除了注释方式外,Hibernate Validator还提供了一套强大的API,通过编程方式来进行校验和验证。通过ValidatorFactory和Validator两个主要的接口,可以创建Validator对象并执行校验操作。可以验证单个属性的值,也可以验证整个JavaBean对象。 Hibernate Validator还提供了国际化的支持,可以根据不同的区域设置显示不同的错误信息。同时,还能够将校验错误信息与具体的校验注释进行关联,方便开发者快速定位问题。 总结来说,Hibernate Validator提供了一种有效、灵活和方便的方式来对JavaBean进行校验。它的注释和API丰富多样,并且支持自定义校验规则,同时还提供了国际化和错误信息关联等特性,使得校验过程更加强大和可控。它在Java开发中的应用越来越广泛,为开发者提供了一种便捷的校验解决方案。 ### 回答3: Hibernate Validator是一个基于JSR 380规范的校验框架,它可以轻松地对Java对象进行校验。通过使用Hibernate Validator,开发人员可以在应用程序中方便地添加校验规则,并且可以验证这些规则是否被满足。 Hibernate Validator提供了一组注解,这些注解可以附加在JavaBean的属性上,以标识需要进行校验的规则。例如,@NotNull注解用于确保属性的值不为空,@Size注解用于确保字符串类型的属性的长度在指定范围内,等等。除了注解外,Hibernate Validator还提供了一些内置的校验器,用于验证各种数据类型的属性,例如字符串、数字、日期等。 使用Hibernate Validator进行校验非常简单。只需要在需要校验JavaBean上添加注解,并在需要校验的时候调用校验方法即可。校验方法会返回一个包含校验结果的对象,开发人员可以根据需要进行处理。校验方法还可以接受一个可选的校验分组参数,用于校验不同场景下的不同规则。 Hibernate Validator还提供了一些扩展功能,用于自定义校验规则。开发人员可以创建自定义的校验注解,并编写相应的校验器来实现特定的校验逻辑。这使得Hibernate Validator非常灵活,可以满足各种不同的校验需求。 总结来说,Hibernate Validator是一个强大而灵活的校验框架,能够方便地对Java对象进行校验。使用Hibernate Validator可以增加应用程序的稳定性和可靠性,减少错误和异常的发生。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值