文档章节

使用SpringMVC的@Validated注解验证

 瑟青豆
发布于 2018/06/22 20:07
字数 1450
阅读 34
收藏 20

1、SpringMVC验证@Validated的使用

第一步:编写国际化消息资源文件

编写国际化消息资源ValidatedMessage.properties文件主要是用来显示错误的消息定制

 

[java] view plain copy

  1. edit.username.null=用户名不能为空  
  2. edit.password.size=密码最少{min}位,最长{max}位  
  3. ......  

可以将edit.username.null与edit.password.size看为参数,在message中传递,具体请看第二步。

 

第二步:Bean实体类中加注解

首先介绍关于验证注解的类型种类

 

@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之间
@NotEmpty 验证注解的元素值不为null且不为空(字符串长度不为0、集合大小不为0)
@NotBlank 验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格
@Email 验证注解的元素值是Email,也可以通过正则表达式和flag指定自定义的email格式

使用 这些注解很简单,只需要在实体类中的变量属性前面加上该注解即可。

[html] view plain copy

  1. public class User {    
  2.     private String id;   
  3.     @NotEmpty(message = "{edit.username.null}")  
  4.     private String username;  
  5.     @Size(min=6 ,max= 20 ,message = "{edit.password.size}")  
  6.     private String password;  
  7.    ......  
  8. }  

其中{}相当于占位符,将min、max参数传图,同时也将消息文件中定制的错误信息传入,当然也可以直接不使用国际化文件,但是推荐使用,方便统一与修改。

 

[html] view plain copy

  1. public class User {    
  2.     private String id;   
  3.     @NotEmpty(message = "用户名不能为空")  
  4.     private String username;  
  5.     @Size(min=6 ,max= 20 ,message = "密码最少6位,最高20位")  
  6.     private String password;  
  7.    ......  
  8. }  

 

 

第三步:Controller层的编写


Controller层的使用,很简单。需要在相应的方法传入的Bean参数前面增加注解@Validated,还有增加BindingResult参数即可,具体请看代码示例:

[html] view plain copy

  1. @Controller    
  2. public class UserController {    
  3.     
  4.     @RequestMapping("/save")    
  5.     public String save(@Validated User user, BindingResult result) {    
  6.         if(result.hasErrors()) {    
  7.             return "error";    
  8.         }    
  9.         return "success";    
  10.     }    
  11. }  

 

第四步:在View层显示错误信息


这里就不做介绍了,实际项目中会封装好相应的javcscript等方法,只需要调用就可以返回页面提示给用户错误信息。
 

2、@Validated的分组特性


先在记录之前,介绍一下这样的场景:在对用户的帐号密码进行编辑保存以及新增是两种不一样的情况。

编辑修改->保存:只需要验证username与password是否符合条件即可,不需要验证id(因为在数据库中id已经存在)。

新增->保存:新增需要验证username与password是否符合条件,还要验证id。

这时候就用到groups分组分情况对Bean属性变量进行验证,也可以满足多验证。具体的需要一下两个步骤

第一步:创建分组接口类


分组接口类只是普通的接口类并没有多大意义,只是用来标识这个属性哪种情况下被验证,这类似于java.io.Serializable  
 

[html] view plain copy

  1. public interface addUser{   
  2. }   
  3. public interface editUser{  
  4. }  

 

第二步:Controller方法参数中增加xxx.class接口


在对新增的用户进行ID验证,增加@Validated({addUser.class})接口类用来表示新增的User.getId()需要验证。

[html] view plain copy

  1. @Controller    
  2. public class UserController {    
  3.     
  4.     @RequestMapping("/saveAdd")    
  5.     public String saveAddUser(@Validated({addUser.class}) User user, BindingResult result) {    
  6.         if(result.hasErrors()) {    
  7.             return "error";    
  8.         }    
  9.         return "success";    
  10.     }  

 

第三步:Bean中添加groups分组


在User实体类中添加groups分组@NotEmpty(groups={addUser.class})与UserController中@Validated({addUser.class})对应,说明在执行saveAddUser新增用户的情况下,才对新增的用户id进行验证。
 

 

[html] view plain copy

  1. public class User {     
  2.     //在分组addUser时,验证id不能为空,其他情况下不做验证  
  3.     @NotEmpty(groups={addUser.class})  
  4.     private String id;  
  5.     @NotEmpty(message = "用户名不能为空")  
  6.     private String username;  
  7.     @Size(min=6 ,max= 20 ,message = "密码最少6位,最高20位")  
  8.     private String password;  
  9.    ......  
  10. }  

以上三步就可以简单地完成分组验证,但是对分组验证补充一下三点:

第一是:不分配groups分组时,默认每次都需要验证。

第二是:通过groups分组可以对同一个变量进行多个验证,如下代码

[html] view plain copy

  1. //对用户名进行两次不同情况的验证。  
  2. @NotEmpty(groups={First.class})  
  3. @Size(min=1,max=10,groups={Second.class})  
  4. public String username;   


第三是:默认的情况下,不同的分组约束验证是无序的,但是在有些情况下验证的相互约束很重要(比如前一个组验证失败,后面的将不再验证等情况),所以groups分组的验证也有前后验证顺序。使用@GroupSequence注解进行排序。

[html] view plain copy

  1. /*  
  2.  * 分组顺序接口类  
  3.  */  
  4. import javax.validation.GroupSequence;  
  5. //分组序列先Frist再Second  
  6. @GroupSequence({First.class,Second.class})  
  7. public interface Group{  
  8. }  
  9.   
  10. @Controller    
  11. public class UserController {    
  12.     
  13.     @RequestMapping("/saveAdd")    
  14.     public String saveAddUser(@Validated({Group.class}) User user, BindingResult result) {    
  15.         if(result.hasErrors()) {    
  16.             return "error";    
  17.         }    
  18.         return "success";    
  19.     }  

© 著作权归作者所有

共有 人打赏支持
上一篇: 初识Shiro
下一篇: Mysql
粉丝 2
博文 22
码字总数 38004
作品 0
石家庄
私信 提问
jboot中如何优雅的处理请求参数?

jboot中处理请求参数有类似springmvc中的@Validated验证注解吗? 对于请求的json数据有无更好的支持呢?比如springmvc中@RequestBody,现在是使用 @理工男海哥...

君子之耀
2018/08/01
206
1
SpringBoot基础教程2-1-7 数据验证-基础数据验证

概述 数据验证是企业应用开发中必备可少的环节,通常如果使用在业务代码中写死验证逻辑,会导致验证逻辑与业务逻辑耦合。 2. 不合理的验证方式 上述代码,如果需要修改验证,不为空且长度大于...

Mkeeper
2018/07/30
0
0
使用Spring Validation 完成后端数据校验

转载并修改于:使用spring validation完成数据后端校验 前言 Web开发中JS校验可以涵盖大部分的校验职责,如用户名唯一性,生日格式,邮箱格式校验等等常用的校验。但是为了避免用户绕过浏览器...

Jitwxs
2018/10/11
0
0
SpringBoot基础教程2-1-9 数据验证-分组验证

概述 本篇是数据验证系列最后篇,将会给大家介绍;上一篇自定义验证注解中有提到,属性,它正是用来分组验证,解决"一些条件需要验证某个属性,另外的条件不需要验证该属性"的情形。 2. 源码...

Mkeeper
2018/08/15
0
0
Spring4新特性——集成Bean Validation 1.1(JSR-349)到SpringMVC

Spring4新特性——泛型限定式依赖注入 Spring4新特性——核心容器的其他改进 Spring4新特性——Web开发的增强 Spring4新特性——集成Bean Validation 1.1(JSR-349)到SpringMVC Spring4新特性...

咖啡杯
2014/02/18
0
0

没有更多内容

加载失败,请刷新页面

加载更多

OSChina 周一乱弹 —— 白掌柜说了卖货不卖身

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @爱漫爱 :这是一场修行分享羽肿的单曲《Moony》 手机党少年们想听歌,请使劲儿戳(这里) @clouddyy :开不开心? 开心呀, 我又不爱睡懒觉…...

小小编辑
今天
16
3
大数据教程(11.7)hadoop2.9.1平台上仓库工具hive1.2.2搭建

上一篇文章介绍了hive2.3.4的搭建,然而这个版本已经不能稳定的支持mapreduce程序。本篇博主将分享hive1.2.2工具搭建全过程。先说明:本节就直接在上一节的hadoop环境中搭建了! 一、下载apa...

em_aaron
今天
5
0
开始看《JSP&Servlet学习笔记》

1:WEB应用简介。其中1.2.1对Web容器的工作流程写得不错 2:编写Servlet。搞清楚了Java的Web目录结构,以及Web.xml的一些配置作用。特别是讲了@WebServlet标签 3:请求与响应。更细致的讲了从...

max佩恩
今天
5
0
mysql分区功能详细介绍,以及实例

一,什么是数据库分区 前段时间写过一篇关于mysql分表的的文章,下面来说一下什么是数据库分区,以mysql为例。mysql数据库中的数据是以文件的形势存在磁盘上的,默认放在/mysql/data下面(可...

吴伟祥
今天
5
0
SQL语句查询

1.1 排序 通过order by语句,可以将查询出的结果进行排序。放置在select语句的最后。 格式: SELECT * FROM 表名 ORDER BY 排序字段ASC|DESC; ASC 升序 (默认) DESC 降序 1.查询所有商品信息,...

stars永恒
今天
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部