出现了 org.apache.commons.lang.exception.NestableRuntimeException等状况。实在令人头大,翻到了一个很好的帖子说明了这个问题。
原文网址如下:1 http://blog.youkuaiyun.com/zb0567/article/details/7893063
详细版 2 https://blog.youkuaiyun.com/gu_gu_/article/details/50551775
为方便更多的人解决这个问题,现将原文贴出
原错误提示:
七月 24, 2018 9:46:27 上午 org.apache.catalina.core.StandardWrapperValve invoke
严重: Servlet.service() for servlet [FindProductByGroup] in context with path [/anbo_test] threw exception [Servlet execution threw an exception] with root cause
java.lang.ClassNotFoundException: org.apache.commons.lang.exception.NestableRuntimeException
at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1907)
at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1750)
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(Unknown Source)
at java.security.SecureClassLoader.defineClass(Unknown Source)
at org.apache.catalina.loader.WebappClassLoaderBase.findClassInternal(WebappClassLoaderBase.java:3148)
at org.apache.catalina.loader.WebappClassLoaderBase.findClass(WebappClassLoaderBase.java:1388)
at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1876)
at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1750)
at Servlet.FindProductByGroupServlet.doPost(FindProductByGroupServlet.java:37)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:650)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:731)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:219)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:110)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:169)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:962)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:445)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1115)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:637)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:318)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Unknown Source)
ava.lang.ClassNotFoundException: org.apache.commons.lang.exception.NestableRuntimeException
遇到这种问题是因为jar包不全,应该包含
commons-beanutils-1.8.3.jar
commons-lang-2.5.jar
ezmorph-1.0.6.jar
json-lib-2.3-jdk15.jar
但是又出现如下问题:
java.lang.ClassNotFoundException: org.apache.commons.logging.LogFactory
导入commons-logging-1.1.1.jar
又出现如下问题:
java.lang.NoClassDefFoundError: Could not initialize class net.sf.json.JSONArray
导入commons-collections 3.2 OK
我按照这个步骤做了下去,在第一部后就发生了问题即在加入
commons-beanutils-1.8.3.jar
commons-lang-2.5.jar (我加入的是3.版本)*
ezmorph-1.0.6.jar
json-lib-2.3-jdk15.jar
这些包以后仍然出现java.lang.ClassNotFoundException: org.apache.commons.lang.* (其中*代表可能出现的一些情况)。结合后面问题的解决方法,我明白了这是因为comms.lang包有问题,因为我明明已经加入了lang包,但是仍然未能找到。后来在百度上查,看来有很多人都遇到了问题,其中看到了一个非常有价值的评论如图:
所以我果断换成了2.*的lang版本。果然最后按照以上作者的步骤顺利的解决了所有问题。
为免除大家找jar包的玛法,我已经贴出了下载的地址,其中包括全部所需要的jar包。下载地址:http://download.youkuaiyun.com/detail/gu_gu_/9412495