2011-11-15 38 views
0

首先,我创建了一个Java应用程序来测试我的代码,以使用蓝牙与NXT Brick联系。一旦这个工作,我创建了一个Web服务,而不是通过蓝牙连接到NXT Brick。lejos noclassdeffounderror lejos/pc/comm/NXTComm

这是问题开始的地方。我的Web服务工作正常,我可以看到服务,我可以调用它们。 一项服务使用Lejos PC库(lejos.pc.comm.NXTComm)中的NXTComm。我已经将这些库添加到项目中,并添加了“import lejos.pc.comm。*;”在班级的顶部,但我仍然遇到以下错误。

[ERROR] lejos/pc/comm/NXTComm 
java.lang.reflect.InvocationTargetException 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
at java.lang.reflect.Method.invoke(Unknown Source) 
at org.apache.axis2.rpc.receivers.RPCUtil.invokeServiceClass(RPCUtil.java:212) 
at org.apache.axis2.rpc.receivers.RPCMessageReceiver.invokeBusinessLogic(RPCMessageReceiver.java:117) 
at org.apache.axis2.receivers.AbstractInOutMessageReceiver.invokeBusinessLogic(AbstractInOutMessageReceiver.java:40) 
at org.apache.axis2.receivers.AbstractMessageReceiver.receive(AbstractMessageReceiver.java:110) 
at org.apache.axis2.engine.AxisEngine.receive(AxisEngine.java:181) 
at org.apache.axis2.transport.http.HTTPTransportUtils.processHTTPPostRequest(HTTPTransportUtils.java:172) 
at org.apache.axis2.transport.http.AxisServlet.doPost(AxisServlet.java:146) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:641) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:224) 
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:169) 
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168) 
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100) 
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:929) 
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:405) 
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:964) 
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:515) 
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302) 
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(Unknown Source) 
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) 
at java.lang.Thread.run(Unknown Source) 
Caused by: java.lang.NoClassDefFoundError: lejos/pc/comm/NXTComm 
at mindstorms.Connector.getBots(Connector.java:111) 
at mindstorms.MindstormService.getBots(MindstormService.java:30) 
... 29 more 
Caused by: java.lang.ClassNotFoundException: lejos.pc.comm.NXTComm 
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1678) 
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1523) 
... 31 more 

为什么服务不能到达这些库,我应该怎么做才能解决这个问题?

+0

验证类** lejos.pc.comm.NXTComm **在类路径中运行时是否可用? – ManuPK

+0

这是我得到,如果我输出 System.out.println(“classpath =”+ System.getProperty(“java.class.path”)); classpath = D:\ Program Files \ Apache Software Foundation \ Tomcat 7.0 \ bin \ bootstrap.jar; D:\ Program Files \ Apache Software Foundation \ Tomcat 7.0 \ bin \ tomcat-juli.jar 因此,它不是那里为什么没有更多呢?你确定它应该在那里? – hhoud

回答

0

那么,为了将leJOS库添加到Web应用程序中,你做了什么?你为什么期望,他们在类路径中?

它可能工作,如果你只是从文件夹中的lib/pc文件中的jar文件分发到Web应用程序的WEB-INF/lib文件夹中,或者,所有Web应用程序都可以访问库的目录。它必须位于Tomcat所在的地方。

BTW:系统属性java.class.path并不真正返回搜索类的路径。如果有人使用类加载器(这是tomcat的做法),那么他们搜索的路径不会出现在java.class.path中。