在jar文件中调用class时获取Invocationtargetexception

时间:2014-12-01 19:32:39

标签: java eclipse class parsing

我在运行Yosemite的MacBook Pro上运行Tomcat8。我在Eclipse Luna中创建了一个Web服务,如果我没有在其他项目中引用一个类,那就可以了。类名是Token。它在IDE中得到解决。在Web服务中,我期望参数" userToken"目前的形式是' S:m:n:userId:name:organization:role:state'。如果我省略参数中的一个项目,我会得到一个StringTokenizer异常,告诉我Web服务正在将参数传递给Token类,其中StringTokenizer过早地用完了标记。我添加这个,因为它似乎正在找到并正在处理该类。如果我为tokenizer提供了一个有效参数和正确数量的项目,我会得到一个我无法弄清楚的调用目标异常。

以下是我在IDE控制台中获得的堆栈跟踪的一部分:

java.lang.reflect.InvocationTargetException
    at org.apache.axis.message.SOAPFaultBuilder.createFault(SOAPFaultBuilder.java:222)
    at org.apache.axis.message.SOAPFaultBuilder.endElement(SOAPFaultBuilder.java:129)
    at org.apache.axis.encoding.DeserializationContext.endElement(DeserializationContext.java:1087)
    at org.apache.xerces.parsers.AbstractSAXParser.endElement(Unknown Source)
    at org.apache.xerces.impl.XMLNSDocumentScannerImpl.scanEndElement(Unknown Source)
    at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl$FragmentContentDispatcher.dispatch(Unknown Source)
    at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanDocument(Unknown Source)
    at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source)
    at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source)
    at org.apache.xerces.parsers.XMLParser.parse(Unknown Source)
    at org.apache.xerces.parsers.AbstractSAXParser.parse(Unknown Source)
    at org.apache.xerces.jaxp.SAXParserImpl$JAXPSAXParser.parse(Unknown Source)
    at javax.xml.parsers.SAXParser.parse(SAXParser.java:392)
    at org.apache.axis.encoding.DeserializationContext.parse(DeserializationContext.java:227)
    at org.apache.axis.SOAPPart.getAsSOAPEnvelope(SOAPPart.java:696)
    at org.apache.axis.Message.getSOAPEnvelope(Message.java:435)
    at org.apache.axis.handlers.soap.MustUnderstandChecker.invoke(MustUnderstandChecker.java:62)
    at org.apache.axis.client.AxisClient.invoke(AxisClient.java:206)
    at org.apache.axis.client.Call.invokeEngine(Call.java:2784)
    at org.apache.axis.client.Call.invoke(Call.java:2767)
    at org.apache.axis.client.Call.invoke(Call.java:2443)
    at org.apache.axis.client.Call.invoke(Call.java:2366)
    at org.apache.axis.client.Call.invoke(Call.java:1812)
    at com.shoulderscorp.services.StateMachineWSSoapBindingStub.getUsersApplicationsAndProcesses(StateMachineWSSoapBindingStub.java:106)
    at com.shoulderscorp.services.StateMachineWSProxy.getUsersApplicationsAndProcesses(StateMachineWSProxy.java:50)
    at org.apache.jsp.home_jsp._jspService(home_jsp.java:322)
    at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:725)
    at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:432)
    at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:396)
    at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:340)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:725)

如果我提供参数的一部分,则此方法' getUsersApplicationsAndProcesses'需要,即组织,并且不进行解析,然后方法正常工作并返回在浏览器中正确显示的xml。

  1. 有人可以给我一些关于可能发生的事情的暗示。顺便说一句,如果我使用来自' main'的参数运行方法。程序,它工作正常。

  2. 如何追踪错误?我似乎无法使调试器正常工作,并在我的IDE中运行时进入代码。

1 个答案:

答案 0 :(得分:1)

Zounds!我发现了这个问题。我认为在这个网站上提问让我更多地思考它以便解释它,这有助于解决问题。

我没有将其他项目包含在IDE中的部署程序集中。因此它正确编译并在IDE中正确运行,但无法找到该类,该类在部署时位于另一个项目中。当我在Web服务代码中放置Class.forName(" Token")。newInstance()时,我发现了一个提示。

由于这是我尝试使用另一个项目的引用的第一个Web服务,这是我第一次遇到这个问题。我还没有看到一个例子,其中任何地方都有对其他项目的引用。

我相信一些更现实世界的例子对他们来说可能对网站有所帮助,而不是非常简单的,几乎是“Hello,World'我们到处找到的。