在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 上部署 grails 应用程序时创建名为“transactionManagerPostProcessor”的 bean 时出错