【问题标题】:ContextLoaderListener problem while spring is loading upspring 加载时的 ContextLoaderListener 问题
【发布时间】:2010-12-15 20:04:11
【问题描述】:

当我的 spring 加载时,通过抛出 FileNotFoundException 在类路径中找不到 applicationContext.xml,如下所示。请帮我解决这个问题。

我的web.xml内容如下,

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/j2ee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
    version="2.4">
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>/WEB-INF/Context.xml</param-value>
    </context-param>

    <servlet>
        <servlet-name>flex</servlet-name>
        <servlet-class>
            org.springframework.web.servlet.DispatcherServlet
        </servlet-class>
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>/WEB-INF/web-spring-context.xml</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <listener>
        <listener-class>
            org.springframework.web.context.ContextLoaderListener
        </listener-class>
    </listener>

    <servlet-mapping>
        <servlet-name>flex</servlet-name>
        <url-pattern>/messagebroker/*</url-pattern>
    </servlet-mapping>
</web-app>

抛出的异常如下,

严重:异常发送上下文 初始化事件到监听器实例 类的 org.springframework.web.context.ContextLoaderListener org.springframework.beans.factory.BeanDefinitionStoreException: IOException 解析 XML 文档来自 类路径资源 [应用程序上下文.xml];嵌套的 例外是 java.io.FileNotFoundException:类 路径资源 [applicationContext.xml] 无法打开,因为它没有 存在原因: java.io.FileNotFoundException:类 路径资源 [applicationContext.xml] 无法打开,因为它没有 存在于 org.springframework.core.io.ClassPathResource.getInputStream(ClassPathResource.java:135) 在 org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:297) 在 org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:280) 在 org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:131) 在 org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:147) 在 org.springframework.web.context.support.XmlWebApplicationContext.loadBeanDefinitions(XmlWebApplicationContext.java:123) 在 org.springframework.web.context.support.XmlWebApplicationContext.loadBeanDefinitions(XmlWebApplicationContext.java:91) 在 org.springframework.context.support.AbstractRefreshableApplicationContext.refreshBeanFactory(AbstractRefreshableApplicationContext.java:100) 在 org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:298) 在 org.springframework.web.context.support.AbstractRefreshableWebApplicationContext.refresh(AbstractRefreshableWebApplicationContext.java:156) 在 org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:246) 在 org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:184) 在 org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:49) 在 org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3843) 在 org.apache.catalina.core.StandardContext.start(StandardContext.java:4342) 在 org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791) 在 org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771) 在 org.apache.catalina.core.StandardHost.addChild(StandardHost.java:525) 在 org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:926) 在 org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:889) 在 org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:492) 在 org.apache.catalina.startup.HostConfig.start(HostConfig.java:1149) 在 org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311) 在 org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:117) 在 org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053) 在 org.apache.catalina.core.StandardHost.start(StandardHost.java:719) 在 org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045) 在 org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443) 在 org.apache.catalina.core.StandardService.start(StandardService.java:516) 在 org.apache.catalina.core.StandardServer.start(StandardServer.java:710) 在 org.apache.catalina.startup.Catalina.start(Catalina.java:578) 在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native 方法)在 sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 在 java.lang.reflect.Method.invoke(Method.java:585) 在 org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288) 在 org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413) 2009 年 11 月 12 日下午 4:02:09 org.apache.catalina.core.ApplicationContext 日志

当我不想将任何文件命名为applicationContext.xml 时,为什么要查找它?正如web.xml..中明确说明的那样。

【问题讨论】:

    标签: java spring


    【解决方案1】:

    对不起各位,这是由于tomcat中的一个简单问题。

    很久以前,我正在处理一个没有从 tomcat webapp 文件夹中删除的项目。那也是春季项目。

    我通过在我正在处理的当前项目中注释掉 web.xml 中的所有内容来解决这个问题。当我这样做时,它仍在尝试加载弹簧容器。就在那时,我打开了 tomcat manager web 应用程序并眯着眼睛寻找未引导的应用程序。

    我发现了一个未在 tomcat manager web 应用程序中引导的应用程序,然后我删除了该应用程序,现在我的应用程序开始像魅力一样工作......

    【讨论】:

      【解决方案2】:

      您实际上已经配置了两个不同的 Spring 引导加载程序 - ContextConfigListener 将尝试加载一个上下文文件(其名称默认为 applicationContext.xml),然后 DispatcherServlet 将第二个启动并尝试加载您的 /WEB-INF/web-spring-context.xml(DispatcherServlet 将将此上下文加载为第一个的子级)。

      如果您不需要加载两个上下文(或具有父上下文和子上下文),则可以删除 ContextConfigListener 并仅使用 DispatcherServlet。

      更新:您使用的是哪个版本的 Spring?您的堆栈跟踪中的行号与我为 Spring 2.5.6 拥有的 org.springframework.web.context.ContextLoader 的源不匹配。你确定你使用的是同一个版本的 spring-core 和 spring-webmvc?

      【讨论】:

      • -1 ContextLoaderListener 使用(或应该使用)被指定为&lt;context-param&gt;contextConfigLocation,在本例中为/WEB-INF/Context.xml。此处考虑了双上下文配置。
      • contextConfigLocation 指定为context-param,它就在文件的顶部。它也被指定为 servlet 的 init-param
      • skaffman 是正确的 - 我最初阅读时错过了这一点 - 但是我现在想知道 unknown 是否有正确的 Spring 版本
      • 对不起,我错了,我错过了。出于某种原因,我认为上下文参数是在侦听器之后指定的,所以我只是忽略了文件的顶部。
      • 我使用的是spring 2.5.6版。
      【解决方案3】:

      您的 Context.xml 是否尝试从类路径导入 applicationContext.xml?代码如下所示:

      <import resource="classpath:applicationContext.xml"/>
      

      根据堆栈跟踪,它正在尝试从类路径加载该文件(请参阅倒数第二个条目)。我刚刚在我的机器上尝试过,如果找不到根上下文文件,则跟踪的第二行是ServletContextResource.getInputStream,所以它正在读取 Context.xml。

      【讨论】:

      • Context.xml 只有一个 bean 定义的 'ArrayList' 也是用于测试目的。
      猜你喜欢
      • 2017-06-12
      • 2014-12-15
      • 2011-08-28
      • 2013-08-25
      • 1970-01-01
      • 1970-01-01
      • 2016-09-12
      • 1970-01-01
      相关资源
      最近更新 更多