若Spring检测到bean实现了Aware接口,则会为其注入相应的依赖。所以通过让bean实现Aware接口,则能在bean中获得相应的Spring容器资源。
Spring中提供的Aware接口有:
BeanNameAware:注入当前bean对应beanNameBeanClassLoaderAware:注入加载当前bean的ClassLoaderBeanFactoryAware:注入当前BeanFactory容器的引用
其使用setter注入来在应用程序上下文启动期间获取对象。
Aware接口是回调,监听器和观察者设计模式的混合,它表示bean有资格通过回调方式被Spring容器通知。
使对象能够知道容器中定义的bean名称。
public class MyBeanName implements BeanNameAware {
@Override
public void setBeanName(String beanName) {
System.out.println(beanName);
}
}
beanName属性表示在Spring容器中注册的beanid,在我们的实现中,只是显示bean名称。
在Spring配置类中注册这种类型的bean:
@Configuration
public class Config {
@Bean(name = 'myCustomBeanName')
public MyBeanName getMyBeanName() {
return new MyBeanName();
}
}
启动应用程序上下文并从中获取bean:
AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(Config.class);
MyBeanName myBeanName = context.getBean(MyBeanName.class);
setBeanName方法打印出了“myCustomBeanName”。
若从@Bean注解中删除name=“…”代码,则在这种情况下,将getMyBeanName()方法名称分配给bean,所以输出将是“getMyBeanName”。
用于注入BeanFactory对象,就能访问创建对象的BeanFactory。
public class MyBeanFactory implements BeanFactoryAware {
private BeanFactory beanFactory;
@Override
public void setBeanFactory(BeanFactory beanFactory) throws BeansException {
this.beanFactory = beanFactory;
}
public void getMyBeanName() {
MyBeanName myBeanName = beanFactory.getBean(MyBeanName.class);
System.out.println(beanFactory.isSingleton('myCustomBeanName'));
}
}
在setBeanFactory()方法的帮助下,我们将IoC容器中的BeanFactory引用分配给beanFactory属性。
然后,我们可以像在getMyBeanName()函数中一样直接使用它。
初始化MyBeanFactory并调用getMyBeanName()方法:
MyBeanFactory myBeanFactory = context.getBean(MyBeanFactory.class);
myBeanFactory.getMyBeanName();
由于我们已经在前面的示例中实例化了MyBeanName类,因此Spring将在此处调用现有实例。
适用场景
获取bean名称以进行日志记录或埋点,对于BeanFactoryAware,它可以使用扩展代码中的springbean。
大多数情况下,应避免使用任何Aware接口,因为实现这些接口会将代码耦合到Spring框架。
文章为作者独立观点,不代表股票交易接口观点