BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

Bean验证规范初稿发布

| 作者 Charles Humble 关注 905 他的粉丝 ,译者 曹晶 关注 0 他的粉丝 发布于 2008年4月15日. 估计阅读时间: 4 分钟 | QCon上海2018 关注大数据平台技术选型、搭建、系统迁移和优化的经验。
在大多数企业级应用中,数据约束会存在于下面两个地方:
1. 模型中(比较典型的就是数据库架构约束)。
2. 应用程序代码中。
这两处都非常重要。在需要迁移应用程序代码的情况下,数据库约束允许重用底层数据模型。与用模型级约束轻松实现的粒度控制比起来,应用级验证能提供更好的粒度控制(这是不是一个有效的E-mail地址?客户的生日是否尚未到来?),也能更容易地为应用用户提供有意义的错误信息。应用级验证可以完全存在于多个地方,从而造成应用不同层之间大量的重复工作。举例来说,在一个典型的Web应用中,浏览器会执行JavaScript进行简单的域级验证,服务器层则验证更为复杂的业务规则。能在一个地方集中定义验证、在应用的不同层之间共享这些定义,该是非常可取的。

在Hibernate Validator高级开发人员Emmanuel Bernard的带领下,JSR-303旨在标准化Java EE 6的约束元数据模型。规范的初稿已经发布,专家组也在积极征求反馈。做为这项工作的一部分,已经创建了一个论坛,Bernard也开始在Hibernate的博客中发表一系列描述API工作原理的文章(第一部分第二部分)。

知道了JSR-303规范的起源,JSR-303很大程度上受JBoss Hibernate Validations的影响也就不足为怪了,尽管很多其它验证框架(比如Xwork和Apache Commons Validator)也影响了该规范。JSR-303在大多数情况下使用Annotation,并为运行时验证提供标准的APIs来查询元数据。每个约束Annotation都必须定义一个String类型的信息来创建错误信息。错误信息支持国际化。可以对对象的属性、Get方法、类、父类、接口声明约束,验证对象会验证该对象所有的约束。比如说,下面的代码创建了一个叫street1的字符串,它的最大长度是50个字符,而且不允许为空:

@NotEmpty @Max(50)
private String street1;

该框架设计为可扩展的,所以应用能很容易地定义自己特有的补充约束。第一篇博客文章中写道:

“约束由下面部分构成:
• Annotation
• 约束验证实现
Annotation表示对域模型的约束,而验证实现则判断给定的值能否通过约束。”

规范不仅支持实例验证,也支持对象图的验证,那么举例来说,如果ClientDetails Bean包含一个带有一或多个@Valid Annotation的Address Bean,验证器在验证ClientDetails Bean的时候也会验证Address Bean的内容。

规范和Hibernate Validator之间的一个重要不同是组的概念,组提供了创建验证子集的方法。组有一个关联序列(通过@GroupSequence Annotation设置),所以开发人员可以在下一组约束执行之前强制通过一组约束而不产生错误。组也允许JavaBean的部分验证。规范初稿提出了可能有用的两种场景:

“• 第二种组完全运行需要依赖于稳定状态
• 第二种组会严重消耗时间、CPU或内存,应该尽可能避免使用”
Java EE 6平台中多种技术都应该能利用JSR-303。比如说,用ORM工具生成(DDL)时的DLL更新、由Java持久化API进行的插入/更新的实体验证、新的WebBeans API、JavaServerFaces组件,看似都很有希望。

查看英文原文:Initial Draft of the Bean Validation Specification Released

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我
社区评论

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT