博客
关于我
springboot后端数据校验JSR303规范详解
阅读量:720 次
发布时间:2019-03-21

本文共 2662 字,大约阅读时间需要 8 分钟。

后端数据校验JSR303规范详解

本文内容说明:

  • JSR303是由JSR303定义的一组校验规范
  • Hibernate Validator为JSR303提供了一系列标准化校验注解
  • 支持自定义校验规则,主要通过正则表达式实现
  • 可以通过校验结果获取数据校验的详细信息
  • 获取Hibernate Validator的官方文档资源
  • 其他文章可参考编写JSR303分组校验和自定义注解校验相关内容
  • 提醒:前端校验是基础,后端校验是必需,建议结合全局异常捕获来实现数据安全校验。本文将先从基础校验和统一异常处理说起,其他文章可参考分组校验和自定义注解校验的内容。


    一:基础校验

    1、给bean添加注解

    需要注意:- 使用@NotEmpty时,对于非空对象(如字符串、集合等)的校验- 对于Integer类型,建议使用@NotNull,而不是@NotEmpty- 定义自定义校验规则时,可以通过@Pattern注解使用正则表达式- 不同的校验类型有不同的默认提示信息

    代码示例:

    // 示例1:@NotBlankpublic class UserDTO {    @NotBlank(message = "用户名不能为空")     private String username;}// 示例2:自定义正则校验public class BrandEntity {    @Pattern(regexp = "/^[a-zA-Z]$", message = "必须是a-z或A-Z字母")     private String firstLetter;}

    2、在Controller开启校验

    使用Hibernate Validator的校验注解需要在Controller方法上标注@Valid,同时将注解应用到需要校验的对象上

    public R save(@Valid @RequestBody BrandEntity brand) {    // 处理校验结果}

    3、接收校验结果

    通过BindingResult接收校验结果,可以获取校验失败时的具体错误信息

    public R save(@Valid @RequestBody BrandEntity brand, BindingResult result) {    if (result.hasErrors()) {        // 提取校验结果        Map errorMap = new HashMap<>();        result.getFieldErrors().forEach(item -> {            errorMap.put(item.getField(), item.getDefaultMessage());        });        return R.error(400, "数据校验失败").put("data", errorMap);    } else {        brandService.save(brand);        return R.ok();    }}

    4、常用校验注解

    校验类型 注解示例 默认提示信息 使用场景
    @NotBlank @NotBlank(message = "用户名不能为空") 字段内容不能为空(去除空格后的内容也为空) 适用于字符串类型字段
    @NotNull @NotNull(message = "ID不能为空") 字段不为空 适用于所有非空对象(如Integer、String等)
    @Size @Size(min=5, max=10, message = "长度必须在5-10之间") 字段长度在min和max之间 适用于数组、集合、字符串等类型
    @Future @Future(message = "日期必须在未来") 日期必须在当前时间之后 适用于DateCalendar对象
    @Pattern @Pattern(regexp = "^\\d{3}-\\d{4}-\\d{4}$", message = "格式错误") 是否符合正则表达式 定义自定义格式规则

    5、自定义校验规则

    可通过@Pattern注解定义自定义正则表达式,实现对字段格式的更精细控制

    示例:

    ```java@Pattern(regexp = "^\\d{3}-\\d{4}-\\d{4}$", message = "文件格式不正确")private String fileFormat;```

    6、校验默认提示信息

    默认提示信息分为英文和中文版本,英文提示信息来源于Hibernate Validator的默认提示,中文提示信息需单独配置

    图片1:Hibernate Validator提示信息配置

    7、异常处理

    推荐在Controller层配置全局异常处理类,统一处理MethodArgumentNotValidException异常

    ```javapackage com.guli.common.exception;public enum BizCodeEnum { VALID_EXCEPTION(400, "参数校验失败"), UNKNOW_EXCEPTION(500, "系统未知错误");
    private int code;private String msg;BizCodeEnum(int code, String msg) {    this.code = code;    this.msg = msg;}public int getCode() {    return code;}public String getMsg() {    return msg;}

    }

    图片2:全局异常捕获配置

    8、配置依赖关系

    确保在Spring Boot项目中配备了Hibernate Validator相关依赖

    ```xml
    org.springframework.boot
    spring-boot-starter-validation

    总结

    JSR303规范为后端校验提供了统一的标准,Hibernate Validator是实现JSR303校验的最佳选择。推荐在Controller层开启校验,结合BindingResult接收校验结果,并通过全局异常捕获统一处理校验失败的情况。

    转载地址:http://lprrz.baihongyu.com/

    你可能感兴趣的文章
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>
    NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
    查看>>
    NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
    查看>>
    NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
    查看>>
    NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
    查看>>
    NIFI大数据进阶_实时同步MySql的数据到Hive中去_可增量同步_实时监控MySql数据库变化_操作方法说明_01---大数据之Nifi工作笔记0033
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>