2011-12-09 160 views
1

我在將Spring Web應用程序部署到Tomcat 6.0時出現問題。我想部署一些jar到shared/lib(catalina.properties被正確配置);這些jar包含各種bean定義。部署到webapps目錄的主要應用程序使用:Tomcat 6.0中的Spring應用程序的部署問題

<import resource="classpath*:com/**/*.xml"/> 

在部署到shared/lib的jar文件中選取bean定義。

部署到shared/lib的一些bean已更新,現在實現MessageSourceAware接口;該應用程序現在開始時,我得到以下錯誤:

Caused by: java.lang.NoClassDefFoundError: org/springframework/context/MessageSourceAware 
    at java.lang.ClassLoader.defineClass1(Native Method) 
    at java.lang.ClassLoader.defineClassCond(ClassLoader.java:632) 
    at java.lang.ClassLoader.defineClass(ClassLoader.java:616) 
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141) 
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:283) 
    at java.net.URLClassLoader.access$000(URLClassLoader.java:58) 
    at java.net.URLClassLoader$1.run(URLClassLoader.java:197) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:307) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:248) 
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1667) 
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1526) 
    at org.springframework.util.ClassUtils.forName(ClassUtils.java:257) 
    at org.springframework.beans.factory.support.AbstractBeanDefinition.resolveBeanClass(AbstractBeanDefinition.java:408) 
    at org.springframework.beans.factory.support.AbstractBeanFactory.doResolveBeanClass(AbstractBeanFactory.java:1282) 
    at org.springframework.beans.factory.support.AbstractBeanFactory.resolveBeanClass(AbstractBeanFactory.java:1253) 
    ... 72 more 
Caused by: java.lang.ClassNotFoundException: org.springframework.context.MessageSourceAware 
    at java.net.URLClassLoader$1.run(URLClassLoader.java:202) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:307) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:248) 
    ... 89 more 

如果罐子從共享/ lib添加到應用程序的WEB-INF/lib目錄中移動,顯然一切工作正常,但我想如果可能的話將瓶子保持在共享/ lib中。

這看起來像是一個類加載器問題,但是當Spring試圖在shared/lib jars中創建bean時,WEB-INF/lib中的spring-context.jar沒有被加載?

我很困惑;任何幫助將非常感激。

回答

1

由於Tomcat中類加載器的層次性質,最終實現了shared/lib文件夾正好是錯誤放置這些擴展jar的地方。

相反,我寫了一個擴展Tomcat的WebappClassLoader我自己的類裝載器:

public class CustomWebappClassLoader extends WebappClassLoader { 

    public CustomWebappClassLoader() { 
     super(); 
     addCustomRepository(); 
    } 

    public CustomWebappClassLoader(ClassLoader parent) { 
     super(parent); 
     addCustomRepository(); 
    } 

    private void addCustomRepository() { 
     String catalinaHome = System.getProperty("catalina.home"); 
     File dir = new File(catalinaHome, String.format("extensions%slib", File.separator)); 
     for (File file : dir.listFiles()) { 
      if (file.getName().endsWith(".jar")) { 
       String repository = String.format("file:/%s", file.getAbsolutePath()); 
       addRepository(repository); 
      } 
     } 
    } 
} 

這增加了在%CATALINA_HOME%/擴展/ lib下的任何jar包到classpath(與WEB-INF/classes和WEB-沿INF/lib爲應用程序)。然後

下面的行中需要的context.xml:

<Loader loaderClass="com.test.CustomWebappClassLoader" delegate="true"/> 
1

將包含org.springframework.context.MessageSourceAware的jar文件添加到Classpath中。如果您使用Eclipse(我假設您是)右鍵單擊項目,然後單擊Build Path。並將相應的jar文件添加到classpath中。

+0

彈簧-context.jar已經_is_部署到WEB-INF部署應用的/ lib目錄。我假定Spring應用程序上下文嘗試在shared/lib中的「extension」jar中創建bean時,它已經被加載。所以我不知道爲什麼我得到這個錯誤。 –

0

您需要在您的項目WEB-INF/lib文件夾或您的TOMCAT_HOME/lib文件夾中的spring-context-x.y.z.jar(其中xyz是版本號)。

+0

也許我沒有很好地解釋我的問題,但是spring-context-3.0.6.RELEASE.jar已經在我的應用程序的WEB-INF/lib文件夾中。這就是爲什麼我不能真正理解我得到的錯誤。 –

相關問題