表象:
@Value(value = "${lbs.routePlan.url}")
private String routePlanUrl;
@Value引入配置文件的属性失效,日志跟踪routePlanUrl所在类被spring加载了两次,第一次成功的读取到了配置文件中lbs.routePlan.url对应的值,第二次未能读取到配置文件中的值,而将${lbs.routePlan.url}赋值给routePlanUrl。
问题跟踪:
在web.xml中同时配置了ContextLoaderListener和DispatcherServlet,ContextLoaderListener解析了applicationContext.xml生成一个IOC,DispatcherServlet解析了spring-mvc.xml生成了一个IOC,applicationContext.xml中配置的扫描bean扫描了所有bean,同时spring-mvc.xml也扫描了所有的bean,所以导致加载了两次bean。 同时DispatcherServlet解析生成的上下文是ContextLoaderListener解析上下文的子类,tomcat优先从子上下文中取bean,然后再从父类中找bean。所以永远找到的是子上下文中bean。 spring-mvc.xml又没有配置属性置换文件,所以才读取不到配置文件中lbs.routePlan.url的值 。
参考文章: 1.https://www.jianshu.com/p/4386dffc998f spring的bean被加载了两次
2.https://blog.csdn.net/pange1991/article/details/81252644 Spring+SpringMVC重复加载配置而引起的bean被加载两次的问题