JSR303介绍

JSR303-Bean Validation描述:This JSR will define a meta-data model and API for JavaBeanTM validation based on annotations, with overrides and extended meta-data through the
use of XML validation descriptors. 为实体验证定义了元数据模型和API.默认的元数据模型是通过Annotations来描述的,也可以使用XML来重载或扩展。

Bean Validation API并不局限于应用程序的某一层或者哪种编程模型。Bean Validation可以被用在任何一层。

Spring3.x已提供对JSR303的支持。

JSR303常用注解说明:

@NotNull/@Null

验证字段:引用数据类型

注解说明:注解元素必须是非空或空

@Digits

验证字段:byte、short、int、long及各自的包装类型以及BigDecimal、BigInteger、String

注解说明:验证数字构成是否合法

属性说明:integer:指定整数部分数字位数,fraction:指定小数部分数字位数

@Future/Past

验证字段:java.util.Date,java.util.Calendar

注解说明:验证是否在当前系统时间之后/之前

@Max/@Min

验证字段:byte、short、int、long及对应的包装类型以及BigDecimal、BigInteger

注解说明:验证值是否小于等于最大指定整数值或大于等于最小指定整数值

@Pattern

验证字段:String

注解说明:验证字符串是否匹配指定的正则表达式

属性说明:regexp:匹配的正则表达式,flags:指定Pattern.Flag的数值,表示正则表达式的选项

@Size

验证字段:String、Collection、Map和数组

注解说明:验证元素大小是否在指定范围内

属性说明:max:最大长度,min:最小长度,message:提示信息,默认:{constraint.size}

@DecimalMax/@DecimalMin

验证字段:byte、short、int、long及对应的包装类型以及BigDecimal、BigInteger、String

属性说明:验证值是否小于等于最大指定小数值或大于等于最小指定小数值

@Valid

属性说明:验证值是否需要递归调用

例子:

下面的例子在Spring3.1中测试通过

需要导入jar:javax.validation-1.0.0.jar 和hibernate-validation-4.3.0.jar

User类:

  1. /**
  2. * 用户
  3. *
  4. * @author Administrator
  5. */
  6. public class User implements Serializable {
  7. private static final long serialVersionUID = 5383162329852182189L;
  8. @NotEmpty(message = "用户名不能为空") // hibernate的验证注解,因为Spring页面中文本传过来的都是空字符串而不是空内容
  9. @Id
  10. private String userName; // 用户名
  11. @Size(min = 5, max = 32, message = "密码长度应在5-32位之间")
  12. private String password; // 密码
  13. private String role; // 对应角色
  14. private String loginIP; // 登录Ip
  15. /**
  16. * 得到用户名
  17. *
  18. * @return 用户名
  19. */
  20. public String getUserName() {
  21. return userName;
  22. }
  23. /**
  24. * 设置用户名
  25. *
  26. * @param userName
  27. *            用户名
  28. */
  29. public void setUserName(String userName) {
  30. this.userName = userName;
  31. }
  32. /**
  33. * 得到登陆密码
  34. *
  35. * @return 登陆密码
  36. */
  37. public String getPassword() {
  38. return password;
  39. }
  40. /**
  41. * 设置登陆密码
  42. *
  43. * @param password
  44. *            登陆密码
  45. */
  46. public void setPassword(String password) {
  47. this.password = password;
  48. }
  49. /**
  50. * 得到用户角色
  51. *
  52. * @return 用户角色
  53. */
  54. public String getRole() {
  55. return role;
  56. }
  57. /**
  58. * 设置用户角色
  59. *
  60. * @param role
  61. *            用户角色
  62. */
  63. public void setRole(String role) {
  64. this.role = role;
  65. }
  66. /**
  67. * 得到登录IP
  68. *
  69. * @return 登录IP
  70. */
  71. public String getLoginIP() {
  72. return loginIP;
  73. }
  74. /**
  75. * 设置登录IP
  76. *
  77. * @param loginIP
  78. *            登录IP
  79. */
  80. public void setLoginIP(String loginIP) {
  81. this.loginIP = loginIP;
  82. }
  83. }

页面请求的方法:

  1. public String login(@Valid User user, BindingResult result,
  2. HttpServletRequest request, Model model) {
  3. if (result.hasErrors()) {
  4. return "login";
  5. }
  6. return "success"
  7. }

在配置文件中需要对验证对象所在包进行扫描

<property name="packagesToScan" value="package.path" />

Spring3.x JSR-303的更多相关文章

  1. JSR 303标准

    JSR 303是Java为bean数据合法性校验提供的标准框架,JSR 303通过在Bean属性上标注类似于@NotNull.@Max等标准的注解指定校验规则,并通过标准的校验接口对bean进行验证. ...

  2. JSR 303 - Bean Validation 介绍及最佳实践

    JSR 303 - Bean Validation 介绍及最佳实践 JSR 303 – Bean Validation 是一个数据验证的规范,2009 年 11 月确定最终方案.2009 年 12 月 ...

  3. Springboot 使用 JSR 303 对 Controller 控制层校验及 Service 服务层 AOP 校验,使用消息资源文件对消息国际化

    导包和配置 导入 JSR 303 的包.hibernate valid 的包 <dependency> <groupId>org.hibernate.validator< ...

  4. JSR教程1——JSR 303 - Bean Validation介绍

    1.Bean Validation 在任何时候,当你要处理一个应用程序的业务逻辑,数据校验是你必须要考虑和面对的事情.应用程序必须通过某种手段来确保输入进来的数据从语义上来讲是正确的.在通常的情况下, ...

  5. SpringMVC中的 JSR 303 数据校验框架说明

    JSR 303 是java为Bean数据合法性校验提供的标准框架,它已经包含在JavaEE 6.0中. JSR 303 通过在Bean属性上标注类似于@NotNull.@Max等标准的注解指定校验规则 ...

  6. JSR 303 - Bean Validation 介绍及最佳实践(转)

    JSR 303 – Bean Validation 是一个数据验证的规范,2009 年 11 月确定最终方案.2009 年 12 月 Java EE 6 发布,Bean Validation 作为一个 ...

  7. JSR 303 - Bean Validation 是什么?

    关于 Bean Validation JSR 303 - Bean Validation 是jree6 中的一项子规范,JSR 303 - Bean Validation着重解决以下实际问题: 在任何 ...

  8. JSR 303 - Bean Validation 模型验证

    类是转载的,不知道转的哪里的. 此类依赖 JSR 303 – Bean Validation, Hibernate Validator. 代码不能直接运行.意会一下.自己改改. import com. ...

  9. JSR 303 - Bean Validation 简单介绍及用法

    一.JSR-303简单介绍 JSR-303 是 JAVA EE 6 中的一项子规范.叫做 Bean Validation,官方參考实现是Hibernate Validator. 此实现与 Hibern ...

  10. SpringMVC中实现Bean Validation(JSR 303 JSR 349 JSR 380)

    JSR 303是针对bean数据校验提出的一个规范.使用注解方式实现数据校验. 每个注解的用法这里就不多介绍,请移步JSR 303 - Bean Validation 介绍及最佳实践 笔者上面提到的J ...

随机推荐

  1. JSP与Servlet之前台页面自动回复之实现

    [JSP与Servlet之前台页面自动回复之实现] 该内容 来自于imooc的一个视屏教程.http://www.imooc.com/video/4562 就是当点击 发送 的时候把这个对话框内容添加 ...

  2. Python学习笔记之Python的enumerate函数

    Python 的 enumerate() 函数就像是一个神秘的黑箱,你无法简单地用一句话来概括这个函数的作用与用法. enumerate() 函数属于非常有用的高级用法,而对于这一点,很多初学者甚至中 ...

  3. oracle 11g的卸载

    oracle 11g 的卸载主要有两种方式:一种是使用Oracle Universal Installer管理工具,该工具以向导模式进行,比较简单.这里主要讲解第二种卸载数据库的方式-----使用”d ...

  4. 深入理解PHP之:Nginx 与 FPM 的工作机制

    网络上有很多关于如何配置 Nginx + FPM 的文章,但它们更多从操作的角度出发,告诉我们怎么做,但却没有告诉我们为什么要这么做,本文从 Nginx 与 FPM 的工作机制出发,探讨配置背后的原理 ...

  5. 非阻塞套接字与IO多路复用

    我们了解了socket之后已经知道,普通套接字实现的服务端的缺陷:一次只能服务一个客户端! 并且,为了使一个客户端能够不断收发消息,我们还要使用while循环来轮询,这极大地降低了我们的效率 acce ...

  6. zabbix监控windows

    windows  版zabbix_agent下载地址: https://www.zabbix.com/download_agents 解压,有bin和conf两个文件夹 配置: 在windows被监控 ...

  7. CentOS 7 源码安装Ansible 2.x

    1.安装Python 3.x环境 [root@ansible ~]# yum install -y python36 python36-pip git [root@ansible ~]# ln -s ...

  8. JMeter学习(十四)jmeter_断言使用

    先说一下使用断言的目的:在request的返回层面增加一层判断机制.因为request成功了,并不代表结果一定正确.类似于QTP中的检查点检查点.断言的使用方法: step_1:在你选择的Sample ...

  9. iOS动画进阶 - 手摸手教你写 Slack 的 Loading 动画

    如果移动端访问不佳,可以访问我的个人博客 前几天看了一篇关于动画的博客叫手摸手教你写 Slack 的 Loading 动画,看着挺炫,但是是安卓版的,寻思的着仿造着写一篇iOS版的,下面是我写这个动画 ...

  10. 解决com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Specified key was too long; max key length is 767 bytes异常

    错误截图: 解决方法: 用root进入mysql终端,执行以下命令: alter database hive character set latin1;