Bean Validation小结

这篇博客主要介绍了在项目中使用Bean Validation进行数据验证的经验,这是一个基于注解的数据验证接口规范,属于Java EE的一部分。文章提到了Hibernate对Bean Validation的实现,并分享了两篇相关教程链接,一篇来自IBM,另一篇来自OSChina。

最近,前辈们在项目中使用了Bean Validation,于是在晚上找些资料学习一下,

这是通过注解的方式对数据进行一系列的验证,还是比较好理解的。

package org.ygy.demo.validator;

import javax.validation.constraints.Min;
import javax.validation.constraints.NotNull;
import javax.validation.constraints.Size;

import lombok.Data;

@Data
public class UserEntity implements java.io.Serializable {
	private static final long serialVersionUID = -5673164765453841780L;

	@NotNull(message = "ID不能为空!")
	private Integer id;

	@NotNull(message = "姓名不能为空!")
	@Size(min = 2, max = 10, message = "姓名为2-10个字符")
	private String name;

	@NotNull(message = "密码不能为空!")
	@Min(value = 2 , message = "秘密最少2个字符")
	private String password;

}

大概就是这个样子,会在以后的工作中慢慢使用并理解。

package org.ygy.demo.validator;

import java.util.Set;

import javax.validation.ConstraintViolation;
import javax.validation.Validation;
import javax.validation.Validator;
import javax.validation.ValidatorFactory;

import org.junit.Test;

public class ValidatorTest {
	
	@Test
	public void testUserEntity() {
		UserEntity user = new UserEntity();
		user.setId(100);
		user.setName("a");
		user.setPassword("s");
		
		ValidatorFactory factory = Validation.buildDefaultValidatorFactory();
		Validator validator = factory.getValidator();
		
		Set<ConstraintViolation<UserEntity>> validations = validator.validate(user);
		for(ConstraintViolation<UserEntity> each : validations) {
			System.out.println(each.getRootBean());
			System.out.println(each.getRootBeanClass());
			System.out.println(each.getLeafBean());
			System.out.println(each.getPropertyPath());
			System.out.println(each.getMessage());
			System.out.println(each.getInvalidValue());
		}
	}
}


这是Java EE 中的接口规范,Hibernate有自己的实现,

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>

	<groupId>org.ygy.demo</groupId>
	<artifactId>validator</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>jar</packaging>

	<name>validator</name>
	<url>http://maven.apache.org</url>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
	</properties>

	<dependencies>
		<dependency>
			<groupId>junit</groupId>
			<artifactId>junit</artifactId>
			<version>4.10</version>
			<scope>test</scope>
		</dependency>

		<dependency>
			<groupId>org.projectlombok</groupId>
			<artifactId>lombok</artifactId>
			<version>0.12.0</version>
		</dependency>

		<!-- <dependency> <groupId>javax</groupId> <artifactId>javaee-api</artifactId> 
			<version>6.0</version> </dependency> -->

		<dependency>
			<groupId>org.hibernate</groupId>
			<artifactId>hibernate-validator</artifactId>
			<version>4.1.0.CR1</version>
		</dependency>

		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-api</artifactId>
			<version>1.7.5</version>
		</dependency>

		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-log4j12</artifactId>
			<version>1.7.5</version>
		</dependency>

	</dependencies>
</project>


这里还有一篇IBM的文章介绍Bean Validation

http://www.ibm.com/developerworks/cn/java/j-lo-beanvalid/


还有一篇也记下:

http://my.oschina.net/zhaoqian/blog/118458


你提供的这段代码是一个典型的 **Spring Boot 中使用 `@Bean` 和 `@ConfigurationProperties` 配置 Druid 数据源的示例**,但它存在一些潜在的问题或不规范的地方,特别是在参数注入方面。 --- ## ✅ 正确代码示例(改进后) ```java @Bean @ConfigurationProperties("spring.datasource.druid.master") public DataSource masterDataSource() { DruidDataSource dataSource = DruidDataSourceBuilder.create().build(); return dataSource; } ``` ### 🔍 为什么不能传入 `DruidProperties`? 你原来的代码: ```java @Bean @ConfigurationProperties("spring.datasource.druid.master") public DataSource masterDataSource(DruidProperties druidProperties) { DruidDataSource dataSource = DruidDataSourceBuilder.create().build(); return druidProperties.dataSource(dataSource); } ``` 这里存在 **两个问题**: 1. `@ConfigurationProperties` 注解不能和 `@Bean` 一起在方法上使用时注入参数。 2. `druidProperties.dataSource(dataSource)` 这个方法调用是 **非标准** 的,只有在你自定义的 `DruidProperties` 类中才有这个方法。 --- ## ✅ 推荐做法:使用 `@ConfigurationProperties` + `@Bean` ### 1. 定义 `DruidProperties` 类 ```java import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.stereotype.Component; @Component @ConfigurationProperties("spring.datasource.druid") public class DruidProperties { private int initialSize; private int minIdle; private int maxActive; private long maxWait; private String validationQuery; private boolean testWhileIdle; private boolean testOnBorrow; private boolean testOnReturn; // getter/setter } ``` --- ### 2. 在配置类中创建 `DataSource` Bean ```java import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Primary; import javax.sql.DataSource; @Configuration public class DataSourceConfig { @Bean @Primary @ConfigurationProperties("spring.datasource.druid.master") public DataSource masterDataSource() { return DruidDataSourceBuilder.create().build(); } } ``` --- ### 3. application.yml 示例配置 ```yaml spring: datasource: druid: master: url: jdbc:mysql://localhost:3306/master_db username: root password: 123456 driver-class-name: com.mysql.cj.jdbc.Driver initial-size: 5 min-idle: 5 max-active: 20 max-wait: 60000 validation-query: SELECT 1 test-while-idle: true test-on-borrow: false test-on-return: false ``` --- ## ✅ 多数据源配置(可选) 如果你有多个数据源(如 master/slave): ```java @Bean @Primary @ConfigurationProperties("spring.datasource.druid.master") public DataSource masterDataSource() { return DruidDataSourceBuilder.create().build(); } @Bean @ConfigurationProperties("spring.datasource.druid.slave") public DataSource slaveDataSource() { return DruidDataSourceBuilder.create().build(); } ``` --- ## ✅ 小结 | 问题 | 原因 | 解决方案 | |------|------|-----------| | 找不到 `DruidProperties` Bean | 未正确注入或配置 | 确保 `@Component` 和 `@ConfigurationProperties` | | `@ConfigurationProperties` 和 `@Bean` 一起使用时传参失败 | Spring 不支持这种方式 | 拆分配置,直接使用 `DruidDataSourceBuilder` | | 多数据源配置 | 未区分配置前缀 | 使用 `@ConfigurationProperties("spring.datasource.druid.master")` | --- ##
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值