- 浏览: 93800 次
- 性别:
- 来自: 深圳
文章分类
最新评论
在项目的业务属性中,你是不是要经常验证属性的取值范围呢. 想要了解比较优美的解决方案吗?
看看Hibernate Validator 是怎么做的吧.一见到她,相信你就会说: Oh God, 这就是我需要的.
任何获得Matrix授权的网站,转载请保留以下作者信息和链接:
作者:icess(作者的blog:http://blog.matrix.org.cn/page/icess)
关键字:Hibernate Validator
用Annotations 给类或者类的属性加上约束(constraint),在运行期检查属性值是很优雅的.Hibernate Validator就是这样的一个框架.该框架是十分容易的(就像参考文档中宣称的那样),几乎没有什么学习曲线,Validator 是一个验证框架 不需要和Hibernate的其他部分绑定就可以使用,只要在你的项目中添加Hibernate-annotations.jar库就可以了.那么下面就让我们看看怎么使用吧.
Person.java 类
/*
* Created on 2006-1-12 Person.java
* @author
*/
package test.annotation.validator;
import org.hibernate.validator.Length;
import org.hibernate.validator.Min;
import org.hibernate.validator.Valid;
//@Serializability //测试自定义约束
public class Person {
private String name;
private int age;
private Address address;
public Person() {}
@Valid //注意此处
public Address getAddress() {
return address;
}
public void setAddress(Address address) {
this.address = address;
}
@Min(value = 1)
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Length(min = 4)
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
Address.java 类
/*
* Created on 2006-1-12 Address.java
* @author
*/
package test.annotation.validator;
import org.hibernate.validator.Length;
import org.hibernate.validator.Max;
import org.hibernate.validator.Min;
public class Address {
private String street;
private int num;
public Address() {}
@Min(value = 1)
@Max(value = 100)
public int getNum() {
return num;
}
public void setNum(int num) {
this.num = num;
}
@Length(min = 3,max =
public String getStreet() {
return street;
}
public void setStreet(String street) {
this.street = street;
}
}
上面是两个用 Validator Annotations 注释的 类. 每个属性都用 约束限制了. 下面看看测试的类吧:
TestValidator.java 类
/*
* Created on 2006-1-12
* @author icerain
*/
package test.annotation.validator;
import org.hibernate.validator.ClassValidator;
import org.hibernate.validator.InvalidValue;
public class TestValidator {
public void test() {
Address add = new Address();
add.setNum(0);
add.setStreet("1");
Person p = new Person();
p.setAddress(add);
p.setAge(0);
p.setName("ice");
/******************Test validator ********/
// 注意该处只验证了Person 为了说明 @Valid 注释的使用
ClassValidator<Person> classValidator = new ClassValidator<Person> (Person.class);
InvalidValue[] validMessages = classValidator.getInvalidValues(p);
for (InvalidValue value : validMessages) {
System.out.println("InvalidValue 的长度是:" + validMessages.length
+" . 验证消息是: " + value.getMessage()
+ " . PropertyPath 是:" + value.getPropertyPath()
+" .\n\t PropertyName 是: " +value.getPropertyName()
+ "Value 是: " + value.getValue()
+" Bean 是: "+ value.getBean()
+"\n\t BeanClass 是:" + value.getBeanClass());
}
}
public static void main(String[] args) {
new TestValidator().test();
}
}
程序的输出如下
可以看出 没有验证 Address.
当然了 ,你还可以只验证一个属性 , 没有必要验证整个类.只需要在调用classValidator.getInvalidValues(p,"age")方法时 加上你要验证的属性就可以了.如我们只想验证age 属性 把代码改为如下所示:
InvalidValue[] validMessages = classValidator.getInvalidValues(p,"age"); //只验证age 属性
运行结果如下:
InvalidValue 的长度是:1 . 验证消息是: 必须大于等于 1 . PropertyPath 是:age .
PropertyName 是: age. Value 是: 0 Bean 是: test.annotation.validator.Person@1457cb
BeanClass 是:class test.annotation.validator.Person
只是验证了 age 属性.
怎么样 ,很简单吧. 关于 Hibernate Validator 内建的验证Annotations 大家可以看看 API 或者 参考文档(中文版我正在翻译中 请访问我的 Blog 获得最新信息).
如果你要写自己的约束呢 , 你不用担心 ,这也是很容易的. 任何约束有两部分组成: [约束描述符 即注释]the constraint descriptor (the annotation) 和[约束validator 即 实现类] the constraint validator (the implementation class).下面我们扩展Hibernate Test suit 中的一个Test 来讲解一下.
首先: 要声明一个constraint descriptor .如下:
package test.annotation.validator;
import java.lang.annotation.Documented;
import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.METHOD;
import java.lang.annotation.Retention;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
import java.lang.annotation.Target;
import org.hibernate.validator.ValidatorClass;
/**
* Dummy sample of a bean-level validation annotation
*
* @author Emmanuel Bernard
*/
@ValidatorClass(SerializabilityValidator.class)
@Target({METHOD,FIELD,TYPE})
@Retention(RUNTIME)
@Documented
public @interface Serializability {
int num() default 11;
String message() default "bean must be serialiable";
}
@ValidatorClass(SerializabilityValidator.class) 指出了 constraint validator 类.
@Target({METHOD,FIELD,TYPE})
@Retention(RUNTIME)
@Documented
这几个我就不用解释了吧.
Serializability 里面声明了一个 message 显示约束的提示信息. num 只是为了说明一个方面 在这里面没有实际用途用 .
然后就是 实现一个constraint validator 类 该类要实现Validator<ConstraintAnnotation>.这里是SerializabilityValidator.java 如下:
//$Id: SerializabilityValidator.java,v 1.3 2005/11/17 18:12:11 epbernard Exp $
package test.annotation.validator;
import java.io.Serializable;
import org.hibernate.validator.Validator;
/**
* Sample of a bean-level validator
*
* @author Emmanuel Bernard
*/
public class SerializabilityValidator implements Validator<Serializability>, Serializable {
public boolean isValid(Object value) {
//这里只是Validator 里面的 实现验证规则的 方法. value 是要验证的值.
System.out.println("IN SerializabilityValidator isValid:"+value.getClass()+": " +value.toString());
return value instanceof Serializable;
}
public void initialize(Serializability parameters) {
// 在这里可以 取得 constraint descriptor 里面的属性 如上面我们声明的 num
System.out.println("IN SerializabilityValidator: parameters:"+ parameters.num() );
}
}
然后在你的类中应用@Serializability 就可以约束一个类实现Serializable 接口了. 如下:
在我们的Person.java类 添加@Serializability Annotations ,把Person.java 中的 //@Serializability //测试自定义约束 注释去掉就ok了.
运行结果如下:
现在把Person类实现 java.io.Serializable 接口 则没有出现 验证错误消息.
消息的国际化也是很简单的,把Serializability 中的message 改为以{}扩住的 属性文件的Key就可以了
public @interface Serializability {
int num() default 11;
String message() default "{Serializable}"; //"bean must be serialiable"; //消息的国际化
}
然后编辑资料文件. 注意 该资源文件中要包括 Hibernate Validator 内建的资源. 可以在该org\hibernate\validator\resources 包里面的资源文件基础上修改 ,在打包里面 这样就可以了. 自己打包可能不太方便.你可以把该包里面的文件复制出来.然后放到你自己的项目包下在自己编辑, 该测试中 我是放在 test\resources 包下的.
然后在 资源文件中添加 Serializable = '''''' 这么一行, 样例如下:
#DefaultValidatorMessages.properties (DefaultValidatorMessages_zh.properties 不再列出^_^)
#下面是 Hibernate Validator 内建的国际化消息 assertion failed
validator.assertTrue=
assertion failed
validator.future=
must be a future date
validator.length=
length must be between {min} and {max}
validator.max=
must be less than or equal to {value}
validator.min=
must be greater than or equal to {value}
validator.notNull=
may not be null
validator.past=
must be a past date
validator.pattern=
must match "{regex}"
validator.range=
must be between {min} and {max}
validator.size=
#下面是自定义的消息
Serializable=
Bean not Serializable //加上自己定义的国际化消息.
在构造ClassValidator 时要添上 资源文件 如下:(在测试类中)
ClassValidator<Person> classValidator = new ClassValidator<Person> (Person.class,ResourceBundle.getBundle("test.resources.DefaultValidatorMessages"));//加载资源
这样就可以了 . 当然 你还可以 更改 Hibernate Validator 的消息(不是在上面的资源文件中直接修改validator.length = ... 等等 ) , 还记得 Validator 注释中有个 message 元素吗? 你以前用的都是默认值,现在你可以该为你自己定义的了.如:validator.length 我把他改为 "该字符串的长度不符合规定范围范围". 在资源文件中添加一行键值属性对(key定义为 "myMsg")如下:
myMsg=该字符串的长度不符合规定范围范围
并且还要在@Length 注释中提供message的引用的key 如下@Length(min = 4,message = "{myMsg}")
再一次运行测试 ,我们就可以看到上面两条自定义绑定的消息了 .如下:
InvalidValue 的长度是:3 . 验证消息是: Bean 不是 可 Serializable . PropertyPath 是:null .
PropertyName 是: null. Value 是: test.annotation.validator.Person@1bd4722 Bean 是: test.annotation.validator.Person@1bd4722
BeanClass 是:class test.annotation.validator.Person
InvalidValue 的长度是:3 . 验证消息是: 该字符串的长度不符合规定范围范围 . PropertyPath 是:name .
PropertyName 是: name. Value 是: ice Bean 是: test.annotation.validator.Person@1bd4722
BeanClass 是:class test.annotation.validator.Person
怎么样,比你想象的简单吧.
OK 上面我们讨论了 Hibernate Validator 的主要用法: 但是 该框架有什么用呢? ^_^
看到这里其实不用我在多说了 大家都知道怎么用,什么时候用. 作为一篇介绍性文章我还是在此给出一个最常用的例子吧,更好的使用方式大家慢慢挖掘吧.
比如 : 你现在在开发一个人力资源(HR)系统 (其实是我们ERP课程的一个作业 ^_^), 里面要处理大量的数据,尤其是在输入各种资料时 如 登记员工信息. 如果你公司的员工的年龄要求是18 -- 60 那么你所输入的年龄就不能超出这个范围. 你可能会说这很容易啊 , 不用Validator就可以解决啊.这保持数据前验证就可以啦 如if ( e.getAge() > 60 || e.getAge() < 18 ) ........ 给出错误信息 然后提示重新输入不就OK啦 用得着 兴师动众的来个第三方框架吗?
是啊 当就验证这一个属性时, 没有必要啊 ! 但是一个真正的HR 系统,会只有一个属性要验证吗? 恐怕要有N多吧
你要是每一个都那样 写一段验证代码 是不是很烦啊 ,况且也不方便代码重用. 现在考虑一些 Validator 是不是更高效啊,拦截到 约束违例的 属性 就可以直接得到 国际化的消息 可以把该消息显示到一个弹出对话框上 提示更正 !
size must be between {min} and {max}
validator.assertFalse=
InvalidValue 的长度是:3 . 验证消息是: bean must be serialiable . PropertyPath 是:null .
PropertyName 是: null. Value 是: test.annotation.validator.Person@1a73d3c Bean 是: test.annotation.validator.Person@1a73d3c
BeanClass 是:class test.annotation.validator.Person
InvalidValue 的长度是:4 . 验证消息是: 必须大于等于 1 . PropertyPath 是:age .
PropertyName 是: age. Value 是: 0 Bean 是: test.annotation.validator.Person@dd87b2
BeanClass 是:class test.annotation.validator.Person
InvalidValue 的长度是:4 . 验证消息是: 长度必须介于 4 与 2147483647 之间 . PropertyPath 是:name .
PropertyName 是: name. Value 是: ice Bean 是: test.annotation.validator.Person@dd87b2
BeanClass 是:class test.annotation.validator.Person
InvalidValue 的长度是:4 . 验证消息是: 必须大于等于 1 . PropertyPath 是:address.num .
PropertyName 是: num. Value 是: 0 Bean 是: test.annotation.validator.Address@197d257
BeanClass 是:class test.annotation.validator.Address
InvalidValue 的长度是:4 . 验证消息是: 长度必须介于 3 与 8 之间 . PropertyPath 是:address.street .
PropertyName 是: street. Value 是: 1 Bean 是: test.annotation.validator.Address@197d257
BeanClass 是:class test.annotation.validator.Address
可以看出不满足约束的值都被指出了.
同时该句: ClassValidator<Person> classValidator = new ClassValidator<Person> (Person.class);
我们只验证了 Person. 在Person里面的Address的属性 由于有@Valid Annotations 所以 Address的相关属性也被机联验证了 .
如果 把@Valid Annotations 去掉,结果如下:
InvalidValue 的长度是:2 . 验证消息是: 必须大于等于 1 . PropertyPath 是:age .
PropertyName 是: age. Value 是: 0 Bean 是: test.annotation.validator.Person@18fef3d
BeanClass 是:class test.annotation.validator.Person
InvalidValue 的长度是:2 . 验证消息是: 长度必须介于 4 与 2147483647 之间 . PropertyPath 是:name .
PropertyName 是: name. Value 是: ice Bean 是: test.annotation.validator.Person@18fef3d
BeanClass 是:class test.annotation.validator.Person
看看Hibernate Validator 是怎么做的吧.一见到她,相信你就会说: Oh God, 这就是我需要的.
任何获得Matrix授权的网站,转载请保留以下作者信息和链接:
作者:icess(作者的blog:http://blog.matrix.org.cn/page/icess)
关键字:Hibernate Validator
用Annotations 给类或者类的属性加上约束(constraint),在运行期检查属性值是很优雅的.Hibernate Validator就是这样的一个框架.该框架是十分容易的(就像参考文档中宣称的那样),几乎没有什么学习曲线,Validator 是一个验证框架 不需要和Hibernate的其他部分绑定就可以使用,只要在你的项目中添加Hibernate-annotations.jar库就可以了.那么下面就让我们看看怎么使用吧.
Person.java 类
/*
* Created on 2006-1-12 Person.java
* @author
*/
package test.annotation.validator;
import org.hibernate.validator.Length;
import org.hibernate.validator.Min;
import org.hibernate.validator.Valid;
//@Serializability //测试自定义约束
public class Person {
private String name;
private int age;
private Address address;
public Person() {}
@Valid //注意此处
public Address getAddress() {
return address;
}
public void setAddress(Address address) {
this.address = address;
}
@Min(value = 1)
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Length(min = 4)
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
Address.java 类
/*
* Created on 2006-1-12 Address.java
* @author
*/
package test.annotation.validator;
import org.hibernate.validator.Length;
import org.hibernate.validator.Max;
import org.hibernate.validator.Min;
public class Address {
private String street;
private int num;
public Address() {}
@Min(value = 1)
@Max(value = 100)
public int getNum() {
return num;
}
public void setNum(int num) {
this.num = num;
}
@Length(min = 3,max =
public String getStreet() {
return street;
}
public void setStreet(String street) {
this.street = street;
}
}
上面是两个用 Validator Annotations 注释的 类. 每个属性都用 约束限制了. 下面看看测试的类吧:
TestValidator.java 类
/*
* Created on 2006-1-12
* @author icerain
*/
package test.annotation.validator;
import org.hibernate.validator.ClassValidator;
import org.hibernate.validator.InvalidValue;
public class TestValidator {
public void test() {
Address add = new Address();
add.setNum(0);
add.setStreet("1");
Person p = new Person();
p.setAddress(add);
p.setAge(0);
p.setName("ice");
/******************Test validator ********/
// 注意该处只验证了Person 为了说明 @Valid 注释的使用
ClassValidator<Person> classValidator = new ClassValidator<Person> (Person.class);
InvalidValue[] validMessages = classValidator.getInvalidValues(p);
for (InvalidValue value : validMessages) {
System.out.println("InvalidValue 的长度是:" + validMessages.length
+" . 验证消息是: " + value.getMessage()
+ " . PropertyPath 是:" + value.getPropertyPath()
+" .\n\t PropertyName 是: " +value.getPropertyName()
+ "Value 是: " + value.getValue()
+" Bean 是: "+ value.getBean()
+"\n\t BeanClass 是:" + value.getBeanClass());
}
}
public static void main(String[] args) {
new TestValidator().test();
}
}
程序的输出如下
可以看出 没有验证 Address.
当然了 ,你还可以只验证一个属性 , 没有必要验证整个类.只需要在调用classValidator.getInvalidValues(p,"age")方法时 加上你要验证的属性就可以了.如我们只想验证age 属性 把代码改为如下所示:
InvalidValue[] validMessages = classValidator.getInvalidValues(p,"age"); //只验证age 属性
运行结果如下:
InvalidValue 的长度是:1 . 验证消息是: 必须大于等于 1 . PropertyPath 是:age .
PropertyName 是: age. Value 是: 0 Bean 是: test.annotation.validator.Person@1457cb
BeanClass 是:class test.annotation.validator.Person
只是验证了 age 属性.
怎么样 ,很简单吧. 关于 Hibernate Validator 内建的验证Annotations 大家可以看看 API 或者 参考文档(中文版我正在翻译中 请访问我的 Blog 获得最新信息).
如果你要写自己的约束呢 , 你不用担心 ,这也是很容易的. 任何约束有两部分组成: [约束描述符 即注释]the constraint descriptor (the annotation) 和[约束validator 即 实现类] the constraint validator (the implementation class).下面我们扩展Hibernate Test suit 中的一个Test 来讲解一下.
首先: 要声明一个constraint descriptor .如下:
package test.annotation.validator;
import java.lang.annotation.Documented;
import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.METHOD;
import java.lang.annotation.Retention;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
import java.lang.annotation.Target;
import org.hibernate.validator.ValidatorClass;
/**
* Dummy sample of a bean-level validation annotation
*
* @author Emmanuel Bernard
*/
@ValidatorClass(SerializabilityValidator.class)
@Target({METHOD,FIELD,TYPE})
@Retention(RUNTIME)
@Documented
public @interface Serializability {
int num() default 11;
String message() default "bean must be serialiable";
}
@ValidatorClass(SerializabilityValidator.class) 指出了 constraint validator 类.
@Target({METHOD,FIELD,TYPE})
@Retention(RUNTIME)
@Documented
这几个我就不用解释了吧.
Serializability 里面声明了一个 message 显示约束的提示信息. num 只是为了说明一个方面 在这里面没有实际用途用 .
然后就是 实现一个constraint validator 类 该类要实现Validator<ConstraintAnnotation>.这里是SerializabilityValidator.java 如下:
//$Id: SerializabilityValidator.java,v 1.3 2005/11/17 18:12:11 epbernard Exp $
package test.annotation.validator;
import java.io.Serializable;
import org.hibernate.validator.Validator;
/**
* Sample of a bean-level validator
*
* @author Emmanuel Bernard
*/
public class SerializabilityValidator implements Validator<Serializability>, Serializable {
public boolean isValid(Object value) {
//这里只是Validator 里面的 实现验证规则的 方法. value 是要验证的值.
System.out.println("IN SerializabilityValidator isValid:"+value.getClass()+": " +value.toString());
return value instanceof Serializable;
}
public void initialize(Serializability parameters) {
// 在这里可以 取得 constraint descriptor 里面的属性 如上面我们声明的 num
System.out.println("IN SerializabilityValidator: parameters:"+ parameters.num() );
}
}
然后在你的类中应用@Serializability 就可以约束一个类实现Serializable 接口了. 如下:
在我们的Person.java类 添加@Serializability Annotations ,把Person.java 中的 //@Serializability //测试自定义约束 注释去掉就ok了.
运行结果如下:
现在把Person类实现 java.io.Serializable 接口 则没有出现 验证错误消息.
消息的国际化也是很简单的,把Serializability 中的message 改为以{}扩住的 属性文件的Key就可以了
public @interface Serializability {
int num() default 11;
String message() default "{Serializable}"; //"bean must be serialiable"; //消息的国际化
}
然后编辑资料文件. 注意 该资源文件中要包括 Hibernate Validator 内建的资源. 可以在该org\hibernate\validator\resources 包里面的资源文件基础上修改 ,在打包里面 这样就可以了. 自己打包可能不太方便.你可以把该包里面的文件复制出来.然后放到你自己的项目包下在自己编辑, 该测试中 我是放在 test\resources 包下的.
然后在 资源文件中添加 Serializable = '''''' 这么一行, 样例如下:
#DefaultValidatorMessages.properties (DefaultValidatorMessages_zh.properties 不再列出^_^)
#下面是 Hibernate Validator 内建的国际化消息 assertion failed
validator.assertTrue=
assertion failed
validator.future=
must be a future date
validator.length=
length must be between {min} and {max}
validator.max=
must be less than or equal to {value}
validator.min=
must be greater than or equal to {value}
validator.notNull=
may not be null
validator.past=
must be a past date
validator.pattern=
must match "{regex}"
validator.range=
must be between {min} and {max}
validator.size=
#下面是自定义的消息
Serializable=
Bean not Serializable //加上自己定义的国际化消息.
在构造ClassValidator 时要添上 资源文件 如下:(在测试类中)
ClassValidator<Person> classValidator = new ClassValidator<Person> (Person.class,ResourceBundle.getBundle("test.resources.DefaultValidatorMessages"));//加载资源
这样就可以了 . 当然 你还可以 更改 Hibernate Validator 的消息(不是在上面的资源文件中直接修改validator.length = ... 等等 ) , 还记得 Validator 注释中有个 message 元素吗? 你以前用的都是默认值,现在你可以该为你自己定义的了.如:validator.length 我把他改为 "该字符串的长度不符合规定范围范围". 在资源文件中添加一行键值属性对(key定义为 "myMsg")如下:
myMsg=该字符串的长度不符合规定范围范围
并且还要在@Length 注释中提供message的引用的key 如下@Length(min = 4,message = "{myMsg}")
再一次运行测试 ,我们就可以看到上面两条自定义绑定的消息了 .如下:
InvalidValue 的长度是:3 . 验证消息是: Bean 不是 可 Serializable . PropertyPath 是:null .
PropertyName 是: null. Value 是: test.annotation.validator.Person@1bd4722 Bean 是: test.annotation.validator.Person@1bd4722
BeanClass 是:class test.annotation.validator.Person
InvalidValue 的长度是:3 . 验证消息是: 该字符串的长度不符合规定范围范围 . PropertyPath 是:name .
PropertyName 是: name. Value 是: ice Bean 是: test.annotation.validator.Person@1bd4722
BeanClass 是:class test.annotation.validator.Person
怎么样,比你想象的简单吧.
OK 上面我们讨论了 Hibernate Validator 的主要用法: 但是 该框架有什么用呢? ^_^
看到这里其实不用我在多说了 大家都知道怎么用,什么时候用. 作为一篇介绍性文章我还是在此给出一个最常用的例子吧,更好的使用方式大家慢慢挖掘吧.
比如 : 你现在在开发一个人力资源(HR)系统 (其实是我们ERP课程的一个作业 ^_^), 里面要处理大量的数据,尤其是在输入各种资料时 如 登记员工信息. 如果你公司的员工的年龄要求是18 -- 60 那么你所输入的年龄就不能超出这个范围. 你可能会说这很容易啊 , 不用Validator就可以解决啊.这保持数据前验证就可以啦 如if ( e.getAge() > 60 || e.getAge() < 18 ) ........ 给出错误信息 然后提示重新输入不就OK啦 用得着 兴师动众的来个第三方框架吗?
是啊 当就验证这一个属性时, 没有必要啊 ! 但是一个真正的HR 系统,会只有一个属性要验证吗? 恐怕要有N多吧
你要是每一个都那样 写一段验证代码 是不是很烦啊 ,况且也不方便代码重用. 现在考虑一些 Validator 是不是更高效啊,拦截到 约束违例的 属性 就可以直接得到 国际化的消息 可以把该消息显示到一个弹出对话框上 提示更正 !
size must be between {min} and {max}
validator.assertFalse=
InvalidValue 的长度是:3 . 验证消息是: bean must be serialiable . PropertyPath 是:null .
PropertyName 是: null. Value 是: test.annotation.validator.Person@1a73d3c Bean 是: test.annotation.validator.Person@1a73d3c
BeanClass 是:class test.annotation.validator.Person
InvalidValue 的长度是:4 . 验证消息是: 必须大于等于 1 . PropertyPath 是:age .
PropertyName 是: age. Value 是: 0 Bean 是: test.annotation.validator.Person@dd87b2
BeanClass 是:class test.annotation.validator.Person
InvalidValue 的长度是:4 . 验证消息是: 长度必须介于 4 与 2147483647 之间 . PropertyPath 是:name .
PropertyName 是: name. Value 是: ice Bean 是: test.annotation.validator.Person@dd87b2
BeanClass 是:class test.annotation.validator.Person
InvalidValue 的长度是:4 . 验证消息是: 必须大于等于 1 . PropertyPath 是:address.num .
PropertyName 是: num. Value 是: 0 Bean 是: test.annotation.validator.Address@197d257
BeanClass 是:class test.annotation.validator.Address
InvalidValue 的长度是:4 . 验证消息是: 长度必须介于 3 与 8 之间 . PropertyPath 是:address.street .
PropertyName 是: street. Value 是: 1 Bean 是: test.annotation.validator.Address@197d257
BeanClass 是:class test.annotation.validator.Address
可以看出不满足约束的值都被指出了.
同时该句: ClassValidator<Person> classValidator = new ClassValidator<Person> (Person.class);
我们只验证了 Person. 在Person里面的Address的属性 由于有@Valid Annotations 所以 Address的相关属性也被机联验证了 .
如果 把@Valid Annotations 去掉,结果如下:
InvalidValue 的长度是:2 . 验证消息是: 必须大于等于 1 . PropertyPath 是:age .
PropertyName 是: age. Value 是: 0 Bean 是: test.annotation.validator.Person@18fef3d
BeanClass 是:class test.annotation.validator.Person
InvalidValue 的长度是:2 . 验证消息是: 长度必须介于 4 与 2147483647 之间 . PropertyPath 是:name .
PropertyName 是: name. Value 是: ice Bean 是: test.annotation.validator.Person@18fef3d
BeanClass 是:class test.annotation.validator.Person
发表评论
-
hibernate Annotations 实例
2008-06-18 11:16 2883从 hbm.xml 到 Annotations 任何获得Ma ... -
HibernateUtilSimple
2008-06-17 10:14 888package org.hibernate.auction.p ... -
HibernateUtil
2008-06-17 10:12 3390package org.hibernate.auction.p ... -
Hibernate的缓存机制介绍
2008-06-16 16:51 947缓存是介于应用程序和 ... -
hibernate常用语句
2008-06-16 16:50 1075Session Session lifecycle begin ... -
hibernate 配置
2008-06-16 16:49 1523第 4 章 配置 由于Hibernate是为了 ... -
对象/关系数据库映射基础
2008-06-16 16:47 1561对象和关系数据库之间的映射通常是用一个XML文档( ... -
集合类(Collections)映射
2008-06-16 16:45 975(译者注:在阅读本章的时候,以后整个手册的阅读过程中,我们都会 ... -
Hibernate包作用详解
2008-06-16 16:43 795Hibernate一共包括了23个ja ... -
HibenateMinute(一)
2008-06-16 16:39 916@ Hibernate3.0 àJBOSS @ ORM à「对 ... -
HibenateMinute(二)
2008-06-16 16:37 1218Criteria: Criteria criteria = s ... -
HibenateMinute(三)
2008-06-16 16:35 917hiberate缓存 一般而言,ORM的数据缓存应包含如下几个 ... -
Hibernate关系映射
2008-06-16 16:34 1013第 8 章 关联关系映射 8.1. 介绍 ... -
Hibernate对象共事
2008-06-16 16:32 1087第 11 章 与对象共 ... -
hibernate查询语言
2008-06-16 16:29 2143第 14 章 批量处理(Batch processing ... -
hibernate提升性能
2008-06-16 16:25 1011第 20 章 提升性能 20.1. 抓 ... -
hibernate工具箱指南
2008-06-16 16:23 1434第 21 章 工具箱指南 可以通过一系列Eclip ... -
hibernate体系结构
2008-06-16 16:20 1741第 3 章 体系结构(A ...
相关推荐
3. 配置验证器:创建`ValidatorFactory`实例,然后使用其创建`Validator`对象。 4. 执行验证:使用`Validator`对象的`validate()`方法对对象进行验证,并处理验证结果。 **应用场景** Hibernate Validator广泛应用...
最后,手册还将介绍如何引导Hibernate Validator,包括获取ValidatorFactory和Validator实例的方法。 要注意的是,手册中出现了一些OCR扫描错误或者漏识别的情况,导致部分文字存在识别错误。这可能会对理解手册...
3. **创建验证器实例**: 使用 `ValidatorFactory` 创建 `Validator` 实例。 4. **执行验证**: 调用验证器的 `validate` 方法,传入待验证的对象和感兴趣的验证组。 5. **处理验证结果**: 如果有违反的规则,`...
《深入理解Hibernate Validator:官方参考文档精要》 在探讨Hibernate Validator之前,我们先来了解一下其背景与核心价值。Hibernate Validator是Java Bean Validation(JSR 303)的参考实现,它为开发者提供了一套...
5. **注册与登录验证实例**:描述中的“注册用户登录验证实例”意味着这个压缩包可能包含了一个完整的示例,演示了如何使用Hibernate Validator进行用户注册和登录的数据验证。这通常涉及到邮箱、用户名的唯一性、...
Hibernate Validator是Java社区规范JSR 380的参考实现,它是一个强大的校验器,用于校验Java Bean中的数据。它不仅支持JSR 303 Bean Validation规范定义的基本注解,还包括了一些额外的自定义约束注解。Hibernate ...
校验过程可以分为几个步骤,首先需要获取一个Validator实例,然后通过该实例进行校验。校验失败时,Hibernate Validator提供了丰富的信息反馈,包括ConstraintViolation类中的方法,可以用来解析验证失败的提示信息...
4. 配置:ValidatorFactory,用于创建Validator实例,配置验证的行为。 三、源码解析 1. `ConstraintValidator`:这是所有自定义验证注解的基础类,其中包含`initialize`和`isValid`两个关键方法,前者用于初始化...
例如,可以使用`ValidatorFactory`创建`Validator`实例,然后对需要验证的对象进行`validate`操作。如果验证失败,`Validator`会返回一个包含错误信息的`ConstraintViolation`集合,供开发者处理异常情况。 总之,`...
《深入解析Hibernate Validator 5.0.1.Final源码》 Hibernate Validator是Java Bean Validation规范的实现,它提供了一套强大的数据校验框架,使得开发者可以方便地对Java对象的属性进行验证。5.0.1.Final是...
**Hibernate Validator 深度解析** Hibernate Validator 是一个基于 Java Bean Validation 规范的实现,它是 Hibernate 项目的一部分,主要用于校验对象的属性值。它提供了丰富的注解和API,帮助开发者在Java应用中...
3. **创建验证器**:创建一个Validator实例,用于执行验证操作。 4. **执行校验**:在处理表单提交的控制器方法中,调用验证器的`validate()`方法,传入待验证的对象,它会返回一个包含所有失败验证的...
为了使用Hibernate Validator进行校验,需要获取一个Validator的实例,这可以通过 ValidatorFactory 实例来完成。 文档详细介绍了如何定义约束条件,包括字段级约束、属性级别约束、类级别约束和约束继承。它还讲解...
《深入理解Hibernate Validator:JSR303的实践指南》 Hibernate Validator,作为JSR303(Java Bean Validation)规范的实现,是Java世界中用于数据验证的重要工具。它提供了一种强大的、灵活的方式来验证对象的属性...
`Validator`实例可以从`Validation.buildDefaultValidatorFactory()`创建,然后调用`validate()`方法来验证对象。如果验证失败,`ConstraintViolation`对象会包含有关错误的信息,如违反的约束和错误消息。 `...
最后,文档描述了如何在应用程序中引导和获取Validator实例。 ### 综合应用 通过上述内容,我们可以了解到Hibernate Validator不仅提供了一套完整的Java对象验证机制,还支持通过注解来声明各种约束条件。这些约束...
《Hibernate Validator 深度解析与应用实践》 Hibernate Validator 是Java世界中一款强大的验证框架,它是JSR 303(Bean Validation)和JSR 349(Bean Validation 1.1)规范的参考实现。在hibernate-validator-...
##### 3.2 获取Validator实例 为了验证实体类的数据,首先需要获得一个`Validator`实例。这通常是通过调用`Validation.buildDefaultValidatorFactory().getValidator()`方法来完成的。一旦获得了`Validator`实例,...