它是一个很大的应用程序,并且有多个由 spring 容器加载的 bean xml 文件。
不知何故,有一个 bean(具有相同的 id)被覆盖。
有没有办法告诉spring记录哪个bean是从哪个.xml文件创建的?
它是一个很大的应用程序,并且有多个由 spring 容器加载的 bean xml 文件。
不知何故,有一个 bean(具有相同的 id)被覆盖。
有没有办法告诉spring记录哪个bean是从哪个.xml文件创建的?
您可以创建ReaderEventListener
并记录它们。但是您需要覆盖initBeanDefinitionReader
以设置您的Listener
开启XmlBeanDefinitionReader
(我认为没有其他方法,但可能是......)。
例如:
public class LogReaderEventListener extends EmptyReaderEventListener {
private static final Log log = LogFactory.getLog(LogReaderEventListener.class);
@Override
public void componentRegistered(ComponentDefinition componentDefinition) {
log.info("Registered Component [" + componentDefinition.getName() + "]");
for (BeanDefinition bd : componentDefinition.getBeanDefinitions()) {
String name = bd.getBeanClassName();
if (bd instanceof BeanComponentDefinition) {
name = ((BeanComponentDefinition) bd).getBeanName();
}
log.info("Registered bean definition: [" + name + "]" +
" from " + bd.getResourceDescription());
}
}
public static void main (String[] args) {
ClassPathXmlApplicationContext context = new LogXmlContext("applicationContext.xml");
context.close();
}
}
class LogXmlContext extends ClassPathXmlApplicationContext {
public LogXmlContext(String configLocation) {
super(configLocation);
}
@Override
protected void initBeanDefinitionReader(XmlBeanDefinitionReader reader) {
super.initBeanDefinitionReader(reader);
reader.setEventListener(new LogReaderEventListener());
}
}