【Java教程】Spring IOC 常用注解与使用实例详解

所需工具:

Java

聪明的大脑

勤劳的双手

 

注意:本站只提供教程,不提供任何成品+工具+软件链接,仅限用于学习和研究,禁止商业用途,未经允许禁止转载/分享等

 

教程如下

@Component

注解@component代表spring ioc 会把这个类扫描生成Bean实例

 	@Component
 	public class Role{
 	     @Value("1")
 	     private Long id;
 	     @Value("role_name_1")
 	     private String roleName;
 	     @Value("role_note_1")
 	     private String note;
 	     /***setter and getter****/
 	}

@Autowired

注解@Autowired代表在spring ioc 定位所有的Bean后,这个字段需要按类型来进行注入。

 	@Component
 	public class RoleImpl_1 implements RoleServer{
 	     @Autowired
 	     private Role role = null;
 	
 	     public .....
 	}

@Qualifier

如果一个接口被两次实现,则使用@Autowired注解来进行该接口注入会产生异常,因为@Autowired无法确定要使用的是哪一个实现类。可以使用@Qualifier注解来进行歧义消除。

 	@Component
 	public class RoleController{
 	     @Autowired
 	     @Qualifier("roleImple_2")
 	     private RoleServer server = null;
 	
 	     public .....
 	}

@Bean

在注解都都是通过@component来进行装配Bean,但是@Component只能注解在类上,无法注解到方法上。而注解@Bean可以注解到方法上

 	@Bean(name = "dataSource")
 	public DataSource getDataSource(){
 	     Properties props = new Properties();
 	     props.setProperty("driver","com.mysql.cj.jdbc.Driver");
 	     props.setProperty("url","jdbc:mysql://localhost:3306/db");
 	     ...
 	     try{
 	         dataSource = BasicDataSourceFactory.createDataSource(props);
 	     }catch(Execption e){
 	         e.printStackTrace();
 	     }
 	     return dataSource;
 	}
 	@Component
 	public class RoleController{
 	     @Autowired(name = "dataSource")
 	     private DataSource dataSource = null;
 	
 	     public .....
 	}

@ImportResource

如果我们将DataSource使用xml配置文件来进行配置,我们就无法使用注解@Bean来进行装配。这时注解@ImportResource可以进行混合装配(将第三方的xml引入进来进行装配)。

 	<!--dbSource.xml-->
 	<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
 	     <property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
 	     <property name="url" value="jdbc:mysql://localhost:3306/db"/>
 	     .......
 	</bean& gt;
 	@ComponentScan(basePackages={"com.test"})
 	@ImportResource({"classpath:dbSource.xml"}) //将dbSource.xml配置文件装配到Ioc中来
 	public class ApplicationConfig{
 	}
 	@Component
 	public class RoleController{
 	     @Autowired
 	     private DataSource dataSource = null;
 	
 	     public .....
 	}

如果有多个xml文件,我们都想引用进来,可以在dbSource.xml配置文件中使用import元素来加载它

 	<!--spring-dataSource.xml-->
 	...........
 	<!--dbSource.xml-->
 	<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
 	     <property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
 	     <property name="url" value="jdbc:mysql://localhost:3306/db"/>
 	     .......
 	</bean>
 	<import resourse="spring-dataSource.xml"/>

@Profile

可以解决不同环境的切换需求,例如开发环境和测试环境不同,我们来看代码操作。

 	@Component
 	public class ProfileDataSource{
 	     //开发环境
 	     @Bean(name = "devDataSource")
 	     @Profile("dev")
 	     public DataSource getDevDataSource(){
 	         ......
 	     }
 	
 	     //测试环境
 	     @Bean(name = "testDataSource")
 	     @Profile("test")
 	     public DataSource getTestDataSource(){
 	         ......
 	     }
 	}

当启动java配置Profile时,可以发现两个Bean并不会加载到IOC容器中,需要自行激活Profie。我们可以使用JVM启动目录或在集成测试环境中使用@ActiveProfiles进行定义

 	//使用@ActiveProfiles激活Profie
 	@RunWith(SpringJunit4ClassRunner.class)
 	@ContextConfiguration(classes=ProfileTest.class)
 	@ActiveProfiles("dev") //激活开发环境的Profile
 	public class ProfileTest{
 	
 	}
 	//使用JVM参数激活Profie
 	JAVA_OPTS="-Dspring.profiles.active=test"

@PropertySource

可以使用注解@PropertySource来加载属性文件(properties)。

 	# dataSource.properties
 	jdbc.database.driver=com.mysql.cj.jdbc.Driver
 	jdbc.database.url=jdbc:mysql://localhost:3306/db
 	.......
 	@Configuration
 	@PropertySource(value = {"classpath:dataSource.properties"},{ignoreResourceNotFound=true})
 	public class ApplicationConfig{
 	
 	}

ignoreResourceNotFound=true,如果找不到该属性文件则忽略它。

标签

发表评论