在tomcat中启动我的应用程序时出错

Posted

技术标签:

【中文标题】在tomcat中启动我的应用程序时出错【英文标题】:Error while starting my application in tomcat 【发布时间】:2020-01-07 00:09:45 【问题描述】:

当我尝试从 web.xml 映射 applicationContext.xml 文件以使用 spring ioc 时,我的应用程序没有开始在 catalina.out 中显示以下错误

org.springframework.web.context.ContextLoaderListener

<context-param>
  <param-name>contextConfigLocation</param-name>
  <param-value>
  /WEB-INF/applicationContext.xml
  </param-value>
</context-param>

2019 年 9 月 4 日 14:07:05.707 严重 org.apache.catalina.core.StandardContext.listenerStart 异常 将上下文初始化事件发送到类的侦听器实例 [org.springframework.web.context.ContextLoaderListener] org.springframework.beans.factory.BeanCreationException:错误 创建 ServletContext 中定义的名称为“userService”的 bean 资源 [/WEB-INF/applicationContext.xml]:无法解析引用 在设置构造函数参数时 bean 'employeeService';嵌套的 例外是 org.springframework.beans.factory.BeanCreationException: 创建名称为“employeeService”的 bean 时出错 ServletContext 资源 [/WEB-INF/applicationContext.xml]:不能 解析匹配的构造函数(提示:指定索引/类型/名称参数 用于避免类型歧义的简单参数)在 org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveReference(BeanDefinitionValueResolver.java:326) 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:487) 在 org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:296) 在

org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5165) 在 org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) 在 org.apache.catalina.manager.ManagerServlet.start(ManagerServlet.java:1381) 在 org.apache.catalina.manager.htmlManagerServlet.start(HTMLManagerServlet.java:694) 在 org.apache.catalina.manager.HTMLManagerServlet.doPost(HTMLManagerServlet.java:218) 在 javax.servlet.http.HttpServlet.service(HttpServlet.java:660) 在 javax.servlet.http.HttpServlet.service(HttpServlet.java:741) 在 org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231) 在 org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) 在 org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 在 org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) 在 org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) 在 org.apache.catalina.filters.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:109) 在 org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) 在 org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) 在 org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199) 在 org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96) 在 org.apache.catalina.valves.RemoteAddrValve.invoke(RemoteAddrValve.java:52) 在 org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:137) 在 org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81) 在 org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:660) 在 org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) 在 java.lang.Thread.run(Thread.java:748) 引起: org.springframework.beans.factory.BeanCreationException:错误 创建 ServletContext 中定义的名称为“employeeService”的 bean 资源 [/WEB-INF/applicationContext.xml]:无法解析匹配 构造函数(提示:为简单指定索引/类型/名称参数 参数以避免类型歧义)在 org.springframework.beans.factory.support.ConstructorResolver.autowireConstructor(ConstructorResolver.java:250) 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireConstructor(AbstractAutowireCapableBeanFactory.java:1075) 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:979) 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:487) 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:458) 在 org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:296) 在 org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:223) 在 org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:293) 在 org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:194) 在 org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveReference(BeanDefinitionValueResolver.java:320) ... 55 更多 04-Sep-2019 14:07:05.708 严重 org.apache.catalina.core.StandardContext.startInternal 一个或多个 侦听器无法启动。完整的详细信息将在 合适的容器日志文件

【问题讨论】:

能否显示完整的堆栈跟踪和更多日志(如果有)? 你是否将 ContextLoaderListener 添加到 web.xml 中? 是的,我在 web.xml @Mark 中添加了 ContextListenerLoader 【参考方案1】:

Application Context 是由 web.xml 中定义的 ContextLoaderListener 或 ContextLoaderServlet 初始化的容器,配置如下所示:

 <listener>
         <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>

    <context-param>
         <param-name>contextConfigLocation</param-name>
        <param-value> /WEB-INF/applicationContext.xml  </param-value>
    </context-param>

和 servlet 应用程序上下文的 servlet 标记

<servlet>
   <servlet-name>myservlet</servlet-name>
   <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
   <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>app-servlet.xml</param-value>
   </init-param>
</servlet>

【讨论】:

以上是关于在tomcat中启动我的应用程序时出错的主要内容,如果未能解决你的问题,请参考以下文章

问啥我的web.xml一加Listener,启动tomcat就出错

在新服务器上启动 grails 应用程序时出错(创建名称为“sessionFactory”的 bean 时出错)

在远程调试模式下启动tomcat时出错

在 tomcat 上部署 grails 应用程序时创建名为“transactionManagerPostProcessor”的 bean 时出错

Tomcat------启动出错

在tomcat 7中部署应用程序时出错