[Java Project Promblem Integration]

Reprinted from:http://chenzhou123520.iteye.com/blog/1836987

Eclipse中tomcat部署工程启动后报错:

java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderListener  

at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1678)  

at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1523)  

at org.apache.catalina.core.DefaultInstanceManager.loadClass(DefaultInstanceManager.java:415)  

at org.apache.catalina.core.DefaultInstanceManager.loadClassMaybePrivileged(DefaultInstanceManager.java:397)  

at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:118)  

at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4660)  

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的部署路径.metadata\.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps\下检查了一下,发现工程部署后在WEB-INF文件夹下没有生成lib目录,正常情况下,会生成lib目录并把工程的所有依赖jar包都部署到该目录下。


解决方案:

1.右键点击项目--选择Properties

选择Deployment Assembly,在右边点击Add按钮,在弹出的窗口中选择Java Build Path Entries。如下图所示:

[Java Project Promblem Integration]_第1张图片

2.点击Next,选择Maven Dependencies

[Java Project Promblem Integration]_第2张图片

3.点击Finish,然后可以看到已经把Maven Dependencies添加到Web应用结构中了

[Java Project Promblem Integration]_第3张图片


操作完后,重新部署工程,不再报错了。然后我们再到.metadata\.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps\目录下,发现工程WEB-INF目录下自动生成了lib目录,并且所有的依赖jar包也都已经部署进来。问题因此解决。


Maven project 直接run没有抱错,maven install 打包后抱错

Error: A JNI error has occurred, please check your installation and try again

Exception in thread "main" java.lang.SecurityException: Invalid signature file digest for Manifest main attributes

解决方法: 

打包成jar后, 运行命令 zip -d [jar package].jar META-INF/*.RSA META-INF/*.DSA META-INF/*.SF

note:zip 是linux下的打包命令, 在windows 中需要下载GnuWin32.Zip 程序安装使用。

另外方法:更改pom, 未尝试

  

            org.apache.maven.plugins  

            maven-shade-plugin  

            1.4  

              

                  

                    package  

                      

                        shade  

                      

                      

                          

                              

                                *:*  

                                  

                                    META-INF/*.SF  

                                    META-INF/*.DSA  

                                    META-INF/*.RSA  

                                  

                             

---------------------

作者:不倒翁_lily

来源:CSDN

原文:https://blog.csdn.net/tongtong0704/article/details/53394183/

版权声明:本文为博主原创文章,转载请附上博文链接!

你可能感兴趣的:([Java Project Promblem Integration])