上篇我们说了生成bean的注解,注入属性值的注解等等,但是bean.xml中还剩部分内容:
<context:component-scan base-package="com.dimples"></context:component-scan>和QueryRunner等的配置
这部分内容我们一般放在SpringConfiguration中实现:
@ComponentScan("com.dimples")
public class SpriingConfiguration{
@Bean(name="runner") //把返回值存到spring容器中。该注解有个属性叫name,用于指定bean的id,不指定时默认是方法名。
public QueryRunner createQueryRunner(DataSource dataSource){
return new QueryRunner(dataSource);
}
@Bean(name="dataSource")
public DataSource createDataSource(){
try{
ComboPooledDataSource ds = new ComboPooledDataSource();
ds.setDriverClass("");
ds.setJdbcUrl("");
ds.setUser("");
ds.setPassword("");
return ds;
}catch(Exception e){
throw new RuntimeException(e);
}
}
}
这样一来我们就彻底不需要bean.xml文件了,那么在我们获取容器的时候,就要其他的类来获取了:
ApplicationContext ac = new AnnotationConfigApplicationContext(SpringConfiguration.class);
这个类中还有一个注解@Configuration,这个注解是把当前类看做是配置类,它的作用很尴尬,当我们的SpringConfiguration和bean.xml文件同时存在时,如果把bean.xml移到跟SpringConfiguration同一个包下,那么在获取容器时可以不用写前面的路径。
这是我们自己写的Spring配置类:
@Configuration
public class SpringConfig {
}
然后我们把这个类和bean.xml同时放到com.dimples.config包下,那么我们就可以这么获取容器:
public static void main(String[] args) {
//ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");
ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml", SpringConfig.class);
ICustomerService cust = (ICustomerService) ac.getBean("cust");
ICustomerService cust1 = (ICustomerService)ac.getBean("cust");
System.out.println(cust == cust1);
cust.saveCustomer();
}
可以看到我们在new ac的时候,只写了bean.xml,前面的路径都没写。不过就这点作用,确实也是。。。