在访问servlet时,在Tomcat java.lang.NoClassDefFoundError下?

Oma*_*eji 6 java eclipse tomcat xstream

我正在Eclipse中编写Web应用程序,我正在使用XStream序列化库来生成My JSON.

我已经封装了在我的servelet调用的类中构建JSON的代码.然后封装类有一个主要的测试方法,当我运行它时,一切似乎工作正常.

但是,当我使用调用我的servelet中的类时,我收到一个java.lang.NoClassDefFoundError错误,说我没有加载XStream库.我假设我的构建路径错误,但我已将XStream库设置为项目的构建路径,因此据我所知它应该可行.

这里可能出现什么问题?

以下是确切的例外:

java.lang.ClassNotFoundException: com.thoughtworks.xstream.io.HierarchicalStreamDriver
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1387)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1233)
    at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)
    at SecurePaymentAjaxData.doPost(SecurePaymentAjaxData.java:44)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:286)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:845)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
    at java.lang.Thread.run(Thread.java:619)
Run Code Online (Sandbox Code Playgroud)

这是使用xstream类的相关代码:

XStream xstream = new XStream(new JettisonMappedXmlDriver());
xstream.setMode(XStream.NO_REFERENCES);
xstream.alias("CallDataUpdate", CallDataUpdate.class);
xstream.alias("CardStatus", CardStatus.class);
String jsonData = xstream.toXML(updateData);
Run Code Online (Sandbox Code Playgroud)

我强调这个代码在作为java应用程序运行时工作正常,我确定它与加载库有关,我只是不知道我哪里出错了.

Bri*_*new 11

不要忘记构建方式部署方式之间存在差异.也就是说,您可能正在构建针对XStream的构建,但您还应将其打包在.war文件中以进行部署.

分解你生成的.war文件(jar tvf {filename}查看内容)并检查它是否存在(下面的.jar文件WEB-INF/lib).我怀疑它不是.


Oma*_*eji 10

我发现了这个问题:

如果右键单击项目并选择属性,则可以设置"Java EE模块依赖项"以包括您正在使用的模块.

嘿Presto它的工作原理.

  • 做得好.幕后发生的事情是,这种依赖性告诉编译器将这些库放入部署的WEB-INF/lib目录(可能是WAR文件).<p />当应用程序在应用程序服务器上加载时 - 默认情况下,此路径包含在Web应用程序的类路径中,您的应用程序现在可以"看到"这些类库. (8认同)
  • 请注意,此功能现在称为"部署程序集",请参阅http://stackoverflow.com/questions/3365369/java-ee-module-dependencies-in-web-project (5认同)

小智 8

Java EE模块依赖性似乎是要走的路.但是,Eclipse Helios中的菜单名称已更改:该特定菜单现在位于"Deployment Assembly"下.