首先是要加入下面两个包
hibernate-validator-4.1.0.Final.jar
validation-api-1.0.0.GA.jar
如果在验证不通过的时候进行了添加、更新或删除操作的时候,则会抛出javax.validation.ConstraintViolationException异常
下面是测试用的类
Model2:
import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.ManyToOne; import javax.persistence.Table; import javax.persistence.TableGenerator; import javax.validation.Valid; import javax.validation.constraints.Max; import javax.validation.constraints.Min; import javax.validation.constraints.NotNull; import javax.validation.constraints.Size; import org.hibernate.validator.constraints.Email; import org.hibernate.validator.constraints.URL; @Entity @Table(name="t_Model2") @TableGenerator(name="mytable",initialValue=1,allocationSize=1) public class Model2 { private int id; private String name; private String address; private String phoneNumber; private String email; private int age; private Model3 model3; private String url; @Id @GeneratedValue(generator="mytable",strategy=GenerationType.TABLE) public int getId() { return id; } public void setId(int id) { this.id = id; } @NotNull(message="姓名不能为空!") public String getName() { return name; } public void setName(String name) { this.name = name; } @NotNull(message="地址不能为空!") public String getAddress() { return address; } public void setAddress(String address) { this.address = address; } @Size(max=11,min=11,message="长度只能为11位!") public String getPhoneNumber() { return phoneNumber; } public void setPhoneNumber(String phoneNumber) { this.phoneNumber = phoneNumber; } @Email(message="email地址无效!") @NotNull(message="email地址不能为空!") public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } @NotNull(message = "Model3不能为空!") @Valid @ManyToOne public Model3 getModel3() { return model3; } public void setModel3(Model3 model3) { this.model3 = model3; } @Min(value=18,message="必须年满18岁!") @Max(value=30,message="年龄不能大于30岁!") public int getAge() { return age; } public void setAge(int age) { this.age = age; } @URL(message="无效的URL地址") @NotNull(message = "URL不能为空!") public String getUrl() { return url; } public void setUrl(String url) { this.url = url; } }
Model3:
import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.Table; import javax.validation.constraints.NotNull; @Entity @Table(name="t_Model3") public class Model3 { private int id; private String name; @Id @GeneratedValue public int getId() { return id; } public void setId(int id) { this.id = id; } @NotNull(message="model3的名称不能为空!") public String getName() { return name; } public void setName(String name) { this.name = name; } }
Test类:
import org.springframework.context.ApplicationContext; import com.tiantian.test.model.Model2; import com.tiantian.test.service.Model2Service; import com.tiantian.test20110430.util.Util; public class Test1 { public static void main(String args[]) { ApplicationContext context = Util.getContext(); Model2Service service = context.getBean(Model2Service.class); Model2 model = new Model2(); model.setName("hello"); model.setEmail("testHibernateValidate@sohu.com"); model.setAddress("湖南长沙"); model.setPhoneNumber("15012345678"); String result = Util.validateModel(model);// 返回的验证结果,验证结果就是一个字符串,如果有错误的话则该字符串的长度大于0 System.out.println(result); if (result.length() == 0)// 验证不通过的时候就不添加 service.add(model); } }
上面用到的Util类:
import java.util.Iterator; import java.util.Set; import javax.validation.ConstraintViolation; import javax.validation.Validation; import javax.validation.Validator; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class Util { private static ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml"); public static ApplicationContext getContext() { return context; } public static String validateModel(Object obj) {//验证某一个对象 StringBuffer buffer = new StringBuffer(64);//用于存储验证后的错误信息 Validator validator = Validation.buildDefaultValidatorFactory() .getValidator(); Set<ConstraintViolation<Object>> constraintViolations = validator .validate(obj);//验证某个对象,,其实也可以只验证其中的某一个属性的 Iterator<ConstraintViolation<Object>> iter = constraintViolations .iterator(); while (iter.hasNext()) { String message = iter.next().getMessage(); buffer.append(message); } return buffer.toString(); } }
下面是一些主要的注解:
@AssertTrue //用于boolean字段,该字段只能为true @AssertFalse//该字段的值只能为false @CreditCardNumber//对信用卡号进行一个大致的验证 @DecimalMax//只能小于或等于该值 @DecimalMin//只能大于或等于该值 @Digits(integer=2,fraction=20)//检查是否是一种数字的整数、分数,小数位数的数字。 @Email//检查是否是一个有效的email地址 @Future//检查该字段的日期是否是属于将来的日期 @Length(min=,max=)//检查所属的字段的长度是否在min和max之间,只能用于字符串 @Max//该字段的值只能小于或等于该值 @Min//该字段的值只能大于或等于该值 @NotNull//不能为null @NotBlank//不能为空,检查时会将空格忽略 @NotEmpty//不能为空,这里的空是指空字符串 @Null//检查该字段为空 @Past//检查该字段的日期是在过去 @Size(min=, max=)//检查该字段的size是否在min和max之间,可以是字符串、数组、集合、Map等 @URL(protocol=,host,port)//检查是否是一个有效的URL,如果提供了protocol,host等,则该URL还需满足提供的条件 @Valid//该注解只要用于字段为一个包含其他对象的集合或map或数组的字段,或该字段直接为一个其他对象的引用, //这样在检查当前对象的同时也会检查该字段所引用的对象
相关推荐
hibernate-validator相关依赖jar包,包括jboss-logging-3.1.0.CR2.jar,hibernate-validator-4.3.1.Final.jar,validation-api-1.0.0.GA.jar
`javax.validation-api-1.1.0.Final.jar`,这是Bean Validation的标准API;以及可能的其他依赖,如`classmate-1.0.0.jar`,用于处理类元数据。这些jar文件的导入,可以借助于构建工具如Maven或Gradle完成,或者手动...
hibernate-validator用于验证对象属性。包含hibernate-validator-4.3.0.Final.jar、jboss-logging-3.1.0.CR2.jar、validation-api-1.0.0.GA.jar三个包
标题中的"spring-boot-starter-validation-1.3.5.RELEASE.zip"是一个Spring Boot的启动模块,专注于数据验证功能的版本。Spring Boot是Java生态系统中一个流行的微服务框架,它简化了创建独立、生产级别的Spring应用...
本主题将详细讲解`Hibernate Validator`以及与之相关的`validation-api-2.0.1.Final.jar`、`hibernate-validator-6.0.8.Final.jar`和`jboss-logging-3.3.2.Final.jar`这三个jar包的作用和重要性。 首先,`...
Hibernate Validator,作为Java Bean Validation标准的重要实现,是开发过程中不可或缺的验证工具。4.2.0.Final版本是其历史上的一个重要里程碑,它在功能、性能和稳定性上都有显著提升。本文将对Hibernate ...
JAVA中通过Hibernate-Validation进行参数验证 JAVA中通过Hibernate-Validation进行参数验证是JAVA服务器端代码开发中的一种常用技术。在开发JAVA服务器端代码时,我们会遇到对外部传来的参数合法性进行验证,而...
Hibernate Validator 是一个基于 Bean Validation 规范的实现,是 Hibernate 项目的一部分,主要用于进行 Java 对象的验证。它提供了丰富的约束注解和自定义验证逻辑,使得开发者能够在 Java 应用程序中轻松地进行...
Hibernate,作为Java领域中的一个强大的对象关系映射(ORM)框架,极大地简化了数据库操作,使得开发者可以使用面向对象的方式处理数据库事务。在2016年,传智播客黑马程序员发布的Hibernate教程中,特别选用了...
hibernate-validate涉及的相关jar包,有classmate.jar+hibernate-validator-5.jar+hibernate-validator-annotation-processor-5.jar+jboss-logging-3.1.1.jar+validation-api-1.1.0.jar
Bean Validation 规范对 Java Bean 的验证流程如下:在实际使用中调用 Validator.validate(JavaBeanInstance) 方法后,Bean Validation 会查找在 JavaBeanInstance上所有的约束声明,对每一个约束调用对应的约束验证...
- `hibernate-validator.jar`: 用于数据验证,基于 Bean Validation 规范,确保入参合法性。 - `hibernate-jpa-2.1-api.jar`: 提供 JPA 2.1 的 API,方便开发者调用。 - `ehcache.jar`: EhCache 是 Hibernate ...
在给定的标题和描述中提到了三个重要的JAR包:`validation-api`, `hibernate-validator`以及`jboss-logging`,它们在数据验证中扮演着不同的角色。 首先,`validation-api-1.0.0.GA.jar`是Java Bean Validation API...
在这个项目中,我们关注的是`Hibernate-Validator`,它是JSR 303/JSR 349标准的实现,用于提供后台验证功能。`Hibernate-Validator`使得在SSM框架中对用户输入的数据进行校验变得更加方便和规范。 首先,我们需要...
4. **hibernate-validator.jar**:提供了Bean Validation规范的实现,用于验证Java Bean属性的值,确保数据的正确性。在Hibernate中,数据验证可以集成到持久化操作中,避免无效数据的入库。 5. **dom4j.jar**:这...
Hibernate Validator是Java世界中一个非常重要的验证框架,它是JSR 303(Bean Validation)和JSR 349(Bean Validation 1.1)规范的参考实现。这个规范定义了如何在Java应用程序中对对象(如实体bean)进行验证,...
hibernate-validator是validation-api 代表规范的一个实现
Hibernate Validator 是基于 JSR-303(Java Bean Validation)和 JSR-349(Java Bean Validation 1.1)规范的实现,它提供了一套灵活且强大的验证API,使得开发者能够对对象属性进行校验,确保输入数据的正确性。...
1. 引入依赖:在项目中引入 Hibernate Validator 的 jar 包,如 hibernate-validator-版本号.jar,同时需要引入对应的 javax.validation-api-版本号.jar。 2. 定义验证规则:在实体类的属性上使用 Hibernate ...
4. `validation-api-2.0.1.Final.jar`:Bean Validation 规范 API,定义了验证接口和注解。 接下来,我们探讨如何在项目中使用 Hibernate Validator: 1. **引入依赖**:在 Maven 或 Gradle 构建系统中,添加对应...