Eclipse中tomcat部署工程啓動後報錯:java
嚴重: Error configuring application listener of class org.springframework.web.context.ContextLoaderListener spring
java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderListener apache
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1678) tomcat
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1523) app
at org.apache.catalina.core.DefaultInstanceManager.loadClass(DefaultInstanceManager.java:415) maven
at org.apache.catalina.core.DefaultInstanceManager.loadClassMaybePrivileged(DefaultInstanceManager.java:397) ui
at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:118) spa
at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4660) orm
at org.apache.catalina.core.StandardContext$1.call(StandardContext.java:5226)
at org.apache.catalina.core.StandardContext$1.call(StandardContext.java:5221)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
at java.util.concurrent.FutureTask.run(FutureTask.java:138)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:662)
問題背景:
工程爲maven工程,ContextLoaderListener類位於spring-web-3.1.0.RELEASE.jar包中。檢查了maven的pom.xml,依賴引入正常。在工程Maven Dependencies視圖中也能看到spring-web-3.1.0.RELEASE.jar包被正常引入進來了。
錯誤緣由:
tomcat在發佈項目的時候沒有同時發佈maven依賴所添加的jar包解決方案:
1.右鍵點擊項目--選擇Properties
選擇Deployment Assembly,在右邊點擊Add按鈕,在彈出的窗口中選擇Java Build Path Entries。以下圖所示:
2.點擊Next,選擇Maven Dependencies
3.點擊Finish,而後能夠看到已經把Maven Dependencies添加到Web應用結構中了
操做完後,從新部署工程,再也不報錯了。
能夠查看,咱們的部署以下:
因此最後咱們發佈的war包,解壓後的目錄以下:
解釋一下: 1 .是wepapp下面的東西原本的東西咱們能夠看獲得原來的目錄下東西,發佈在/下面
2.這個是/src/main/java下面的java源碼文件,被編譯後的字節碼文件放在WEB-INF/classes下面
3.mavene Dependeny下面的jia包發佈到/WEB-INF/classes下面。