mit*_*ast 5 java spring spring-bean
我有懒惰初始化bean的代码:
@Component @Lazy
class Resource {...}
@Component @Lazy @CustomProcessor
class ResourceProcessorFoo{
@Autowired
public ResourceProcessor(Resource resource) {...}
}
@Component @Lazy @CustomProcessor
class ResourceProcessorBar{
@Autowired
public ResourceProcessor(Resource resource) {...}
}
Run Code Online (Sandbox Code Playgroud)
初始化应用程序上下文后,没有此bean的实例.当bean资源由应用程序上下文创建时(例如,applicationContext.getBean(Resource.class)),没有@CustomProcessor实例标记bean.
在创建Resource bean时,需要使用@CustomProcessor创建bean.怎么做?
更新:找到一个丑陋的解决方案 - 使用空的自动装配的setter:
@Autowired
public void setProcessors(List<ResourceProcessor> processor){}
Run Code Online (Sandbox Code Playgroud)
Bean BeanPostProcessor的另一个丑陋的解决方案(太神奇了!)
@Component
class CustomProcessor implements BeanPostProcessor{
public postProcessBeforeInitialization(Object bean, String beanName) {
if(bean instanceof Resource){
applicationContext.getBeansWithAnnotation(CustomProcessor.class);
}
}
}
Run Code Online (Sandbox Code Playgroud)
也许有更优雅的方式?
您必须创建一个标记界面,例如CustomProcessor
public interface CustomProcessor{
}
Run Code Online (Sandbox Code Playgroud)
以后每个ResourceProcessor必须实现上面的接口
@Component @Lazy
class ResourceProcessorFoo implements CustomProcessor{
@Autowired
public ResourceProcessor(Resource resource) {...}
}
@Component @Lazy
class ResourceProcessorBar implements CustomProcessor{
@Autowired
public ResourceProcessor(Resource resource) {...}
}
Run Code Online (Sandbox Code Playgroud)
资源必须实现ApplicationContextAware
@Component
@Lazy
public class Resource implements ApplicationContextAware{
private ApplicationContext applicationContext;
@PostConstruct
public void post(){
applicationContext.getBeansOfType(CustomProcessor.class);
}
public void setApplicationContext(ApplicationContext applicationContext)throws BeansException {
this.applicationContext = applicationContext;
}
}
Run Code Online (Sandbox Code Playgroud)
当Resourcebean 被引用时,启动后构造,初始化所有实现CustomProcessor接口的 bean。