java - 在 Tomcat 服务器中部署 WAR 文件时出错 - org.springframework.web.context.ContextLoaderListener 未加载

标签 java spring tomcat war

我的项目在通过 eclipse 和 tomcat 服务器 7 运行的本地计算机上运行良好。我正在通过执行 Maven install 生成 WAR 文件并将其部署到 tomcat 服务器中。部署后项目未运行并显示 404 Not Found

在日志文件中我得到这样的错误:

       SEVERE: Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListener
    org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.security.filterChains': Cannot resolve reference to bean 'org.springframework.security.web.DefaultSecurityFilterChain#0' while setting bean property 'sourceList' with key [0]; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.security.web.DefaultSecurityFilterChain#0': Cannot resolve reference to bean 'preAuthendicationFilter' while setting constructor argument with key [1]; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'preAuthendicationFilter' defined in ServletContext resource [/WEB-INF/spring-security.xml]: Cannot resolve reference to bean 'authenticationManager' while setting bean property 'authenticationManager'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.security.authenticationManager': Cannot resolve reference to bean 'org.springframework.security.authentication.dao.DaoAuthenticationProvider#0' while setting constructor argument with key [1]; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.security.authentication.dao.DaoAuthenticationProvider#0': Cannot resolve reference to bean 'userDetailsService' while setting bean property 'userDetailsService'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'userDetailsService': Injection of autowired dependencies failed; nested exception is org.springframework.beans.factory.BeanCreationException: Could not autowire field: private com.acinfotech.crowdtxt.jpa.service.PersistenceService com.acinfotech.crowdtxt.secure.UserDetailsServiceImpl.persistenceService; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'persistenceService': Injection of autowired dependencies failed; nested exception is org.springframework.beans.factory.BeanCreationException: Could not autowire field: private com.acinfotech.crowdtxt.jpa.util.PropertyUtil com.acinfotech.crowdtxt.jpa.service.PersistenceServiceImpl.propertyUtil; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'propertyUtil' defined in URL [jar:file:/Users/mindpro/Documents/apache-tomcat-7.0.59/webapps/crowdtxt/WEB-INF/lib/crowdtxt-persistence-0.0.1-SNAPSHOT.jar!/com/acinfotech/crowdtxt/jpa/util/PropertyUtil.class]: Instantiation of bean failed; nested exception is java.lang.ExceptionInInitializerError
        at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveReference(BeanDefinitionValueResolver.java:329)
        at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveValueIfNecessary(BeanDefinitionValueResolver.java:107)
        at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveManagedList(BeanDefinitionValueResolver.java:353)
        at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveValueIfNecessary(BeanDefinitionValueResolver.java:154)
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:1417)
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1158)
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:458)
        at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:296)
        at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:223)
        at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:293)
        at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:194)
        at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:610)
        at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:932)
        at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:479)
        at org.springframework.web.context.ContextLoader.configureAndRefreshWebApplicationContext(ContextLoader.java:389)
        at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:294)
        at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:112)
        at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:5016)
        at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5524)
        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
        at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:901)
        at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:877)
        at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:649)
        at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:1081)
        at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1877)
        at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
        at java.util.concurrent.FutureTask.run(FutureTask.java:262)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
        at java.lang.Thread.run(Thread.java:745)   
Caused by: java.lang.NullPointerException
    at com.acinfotech.crowdtxt.jpa.util.PropertyUtil.getPropertiesFromEnvironmentVariable(PropertyUtil.java:86)
    at com.acinfotech.crowdtxt.jpa.util.PropertyUtil.<clinit>(PropertyUtil.java:23)
    ... 119 more

Application-context.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:util="http://www.springframework.org/schema/util"
       xmlns:jpa="http://www.springframework.org/schema/data/jpa"
       xsi:schemaLocation="
       http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
       http://www.springframework.org/schema/data/jpa http://www.springframework.org/schema/data/jpa/spring-jpa.xsd
       http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-3.1.xsd">

    <jpa:repositories base-package="com.acinfotech.crowdtxt.jpa.dao"/>

     <!--Bean to load properties file -->
    <!-- <bean id="placeholderConfig" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> 
        <property name="location" value="file:${CROWDTEXT_PROPERTY_FILE}"/>
    </bean> --> 

    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/crowdtxt"/>
        <property name="username" value="root"/>
        <property name="password" value=""/>
    </bean>

    <bean id="jpaVendorAdapter" class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
        <property name="showSql" value="true"/>
        <property name="generateDdl" value="false"/>
        <property name="database" value="MYSQL"/>
   </bean>

    <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <property name="jpaVendorAdapter" ref="jpaVendorAdapter"/>
        <!-- spring based scanning for entity classes-->
        <property name="packagesToScan" value="com.acinfotech.crowdtxt.jpa.model"/>
    </bean>

    <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"/>

</beans>

有人可以帮我解决问题吗?我找不到我做错的地方。我在 pom.xml

中设置了所有依赖项

最佳答案

刚刚注意到该项目在 eclipse 中运行良好,但在独立服务器中运行良好。复制您在 eclipse tomcat 配置中设置的所有运行时属性,并将其粘贴到独立的 tomcat catalaina 文件中。您可以找到 java opts 并添加它。

存在空指针异常。

Caused by: java.lang.NullPointerException
at com.acinfotech.crowdtxt.jpa.util.PropertyUtil.getPropertiesFromEnvironmentVariable(PropertyUtil.java:86)
at com.acinfotech.crowdtxt.jpa.util.PropertyUtil.<clinit>(PropertyUtil.java:23)
... 119 more

您可以在 PropertyUtil 类的第 86 行放置一个调试点。从方法名getPropertiesFromEnvironmentVariable来看,我猜测是某个环境变量没有设置,或者获取它的值有问题。

如果无法调试,则尝试使用 System.out.println 语句查看什么是 null。

我希望你能从这里调试。

关于java - 在 Tomcat 服务器中部署 WAR 文件时出错 - org.springframework.web.context.ContextLoaderListener 未加载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34690953/

相关文章:

java - 在 Spring Web 上下文中通过 Mock 对象覆盖 Autowiring 字段

java - Android - 如何将 Android 手机连接到计算机的本地主机

java - 不使用 Synchronized 关键字的 Singleton 实现的延迟初始化

java - 在保存 hibernate 实体时忽略 transient 模式

java - JasperReports JAR 文件导致使用 Log4j 进行过多日志记录

java - 为什么将 gradle java 应用程序部署到 heroku 失败?

java - 无效的 bean 定义 : Could not resolve placeholder

java - Spring JPA + EclipseLink ID在触发器中生成

tomcat - Vaadin、Tomcat 7 和 Nginx 作为反向代理

java - 如何通过 https 启动 java servlet?