java spring 校验框架_Springboot 使用校验框架validation校验

b/s系统中对http请求数据的校验多数在客户端进行,这也是出于简单及用户体验性上考虑,但是在一些安全性要求高的系统中服务端校验是不可缺少的。

Spring3支持JSR-303验证框架,JSR-303 是Java EE 6 中的一项子规范,叫做BeanValidation,官方参考实现是hibernate Validator(与Hibernate ORM 没有关系),JSR 303 用于对Java Bean 中的字段的值进行验证。

validation与 springboot 结合

依赖

javax.validation

validation-api

2.0.1.Final

org.hibernate

hibernate-validator

6.0.16.Final

1. bean 中添加标签

部分代码:

标签需要加在属性上,@NotBlank 标签含义文章末尾有解释

public class User{

private Integer id;

@NotBlank(message = "{user.name.notBlank}")

private String name;

private String username;

2. Controller中开启验证

在Controller 中 请求参数上添加@Validated 标签开启验证

@RequestMapping(method = RequestMethod.POST)

public User create(@RequestBody @Validated User user){

return userService.create(user);

}

@RequestMapping(method = RequestMethod.GET)

public User  getUserById(@NotNull(message = "id不能为空")  int userId){

return userService.getUserById(userId);

}

3. resource 下新建错误信息配置文件

当然 message 信息也可以配置在标签后面例如

public class User{

private Integer id;

@NotBlank(message = "名字不能为空")

private String name;

private String username;

也可以在resource 目录下新建提示信息配置文件“ValidationMessages.properties“ 这样可以全局统一管理错误消息

注意:名字必须为“ValidationMessages.properties“ 因为SpringBoot自动读取classpath中的ValidationMessages.properties里的错误信息

ValidationMessages.properties 文件的编码为ASCII。数据类型为 key value 。

key“user.name.notBlank“为第一步 bean的标签 大括号里面对应message的值

value 为提示信息 ,但是是ASCII 。(内容为“名字不能为空“)

70f0959ae6a7ea88bd3d5a21b3a3d47f.png

4. 自定义异常处理器,捕获错误信息

当验证不通过时会抛异常出来,异常的message 就是 ValidationMessages.properties 中配置的提示信息。

此处定义异常处理器。捕获异常信息(因为验证不通过的项可能是多个所以统一捕获处理),并抛给前端。(此处是前后端分离开发)

@ExceptionHandler(MethodArgumentNotValidException.class)

public void MethodArgumentNotValidException(Exception ex, HttpServletRequest request, HttpServletResponse response){

logger.error( ":" + CommonUtil.getHttpClientInfo(request), ex);

MethodArgumentNotValidException c = (MethodArgumentNotValidException) ex;

List errors =c.getBindingResult().getAllErrors();

StringBuffer errorMsg=new StringBuffer();

errors.stream().forEach(x -> errorMsg.append(x.getDefaultMessage()).append(";"));

pouplateExceptionResponse(response, HttpStatus.INTERNAL_SERVER_ERROR, errorMsg.toString());

}

private void pouplateExceptionResponse(HttpServletResponse response, HttpStatus errorCode, String errorMessage){

try {

response.sendError(errorCode.value(), errorMessage);

} catch (IOException e) {

logger.error("failed to populate response error", e);

}

}

5. 附上部分标签含义

ff41bec9c6afc097b068a61d25d29030.png

示例

@Pattern(regexp="^[a-zA-Z0-9]+$",message="{account.username.space}")

@Size(min=3,max=20,message="{account.username.size}")

如果上述的参数校验不满足要求可以 考虑自定义注解

自定义注解校验

步骤:

1、定义注解, 2、实现校验逻辑

用法

public class MySaveArgs{

@NotEmpty

@MustBeMyCode

private String code;

定义注解

@Constraint(

validatedBy = {MyCodeConstraintValidator.class}

)

@Target({ElementType.FIELD, ElementType.PARAMETER})

@Retention(RetentionPolicy.RUNTIME)

public @interface MustBeMyCode {

String message() default "编码校验不通过";

Class>[] groups() default {};

Class extends Payload>[] payload() default {};

}

实现ConstraintValidator 接口,编写自己的校验逻辑,

public class MyCodeConstraintValidator implements ConstraintValidator{

@Override

public boolean isValid(String value, ConstraintValidatorContext context){

//此处编写自己的校验逻辑,并返回

return value != null;

}

}

注意:ConstraintValidator 此处应填写你自己的校验注解名 和 需校验参数类型

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值