【发布时间】:2012-02-13 17:07:33
【问题描述】:
我是 stackOverflow 的新手,所以,再次嗨 =)
我正在使用 Jena Semantic Web Framework、Pellet Reasoner、Eclipse IDE(在 Linux 机器上)和 Virtuoso OSE 来存储我的图表。我还使用 Protege Editor =) 制作了我的本体。
我正在使用 SOAP 开发客户端-服务器应用程序,我编写了一个读取基本模型的程序,通过使用颗粒应用推理并将整个推理模型写入临时 owl 文件,然后,另一个程序读取推理模型模型并将其存储在 Virtuoso 中,因此我可以使用 Python 客户端通过 Virtuoso 的 SPARQL 端点查询它。
问题是,当我调用调用生成推理模型的过程的 Web 服务时,我收到了这条消息(完整的堆栈跟踪在这个问题的末尾)
AxisFault
faultCode: {http://schemas.xmlsoap.org/soap/envelope/}Server.userException
faultSubcode:
faultString: java.lang.reflect.InvocationTargetException
faultActor:
faultNode:
faultDetail:
{http://xml.apache.org/axis/}hostname:leia
这是生成推理模型的例程,也是抛出异常的例程。
public InfModel reasonOverModel(String path) {
Model emptyModel = ModelFactory.createDefaultModel();
// Pellet instance
Reasoner reasoner = PelletReasonerFactory.theInstance().create();
InfModel model = ModelFactory.createInfModel(reasoner, emptyModel);
try {
InputStream in = FileManager.get().open(path);
model.read(in, "");
} catch (Exception ex) {
// TODO: log with log4j
ex.printStackTrace();
return null;
}
return model;
}
它正在从“路径”读取基本模型,并对其应用推理,但它没有返回,我的 catch 子句没有捕获该异常,我不知道为什么。好像是轴的问题。
有什么想法、线索或建议吗? 非常感谢提前 来自加拉加斯的问候 - 委内瑞拉 ----------------------------------------在此处完成 Stacktrace -------------------- ----------
轴故障 故障代码:{http://schemas.xmlsoap.org/soap/envelope/}Server.userException 故障子代码: 故障字符串:java.lang.reflect.InvocationTargetException 故障演员: 故障节点: 故障详情: {http://xml.apache.org/axis/}主机名:leia java.lang.reflect.InvocationTargetException 在 org.apache.axis.message.SOAPFaultBuilder.createFault(SOAPFaultBuilder.java:222) 在 org.apache.axis.message.SOAPFaultBuilder.endElement(SOAPFaultBuilder.java:129) 在 org.apache.axis.encoding.DeserializationContext.endElement(DeserializationContext.java:1087) 在 org.apache.xerces.parsers.AbstractSAXParser.endElement(未知来源) 在 org.apache.xerces.impl.XMLNSDocumentScannerImpl.scanEndElement(未知来源) 在 org.apache.xerces.impl.XMLDocumentFragmentScannerImpl$FragmentContentDispatcher.dispatch(未知来源) 在 org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanDocument(未知来源) 在 org.apache.xerces.parsers.XML11Configuration.parse(未知来源) 在 org.apache.xerces.parsers.XML11Configuration.parse(未知来源) 在 org.apache.xerces.parsers.XMLParser.parse(未知来源) 在 org.apache.xerces.parsers.AbstractSAXParser.parse(未知来源) 在 org.apache.xerces.jaxp.SAXParserImpl$JAXPSAXParser.parse(未知来源) 在 javax.xml.parsers.SAXParser.parse(SAXParser.java:395) 在 org.apache.axis.encoding.DeserializationContext.parse(DeserializationContext.java:227) 在 org.apache.axis.SOAPPart.getAsSOAPEnvelope(SOAPPart.java:696) 在 org.apache.axis.Message.getSOAPEnvelope(Message.java:435) 在 org.apache.axis.handlers.soap.MustUnderstandChecker.invoke(MustUnderstandChecker.java:62) 在 org.apache.axis.client.AxisClient.invoke(AxisClient.java:206) 在 org.apache.axis.client.Call.invokeEngine(Call.java:2784) 在 org.apache.axis.client.Call.invoke(Call.java:2767) 在 org.apache.axis.client.Call.invoke(Call.java:2443) 在 org.apache.axis.client.Call.invoke(Call.java:2366) 在 org.apache.axis.client.Call.invoke(Call.java:1812) 在 com.thesis.server.Admin.updateReasonedModel(Admin.java:21) 在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 在 sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 在 java.lang.reflect.Method.invoke(Method.java:597) 在 org.apache.axis.providers.java.RPCProvider.invokeMethod(RPCProvider.java:397) 在 org.apache.axis.providers.java.RPCProvider.processMessage(RPCProvider.java:186) 在 org.apache.axis.providers.java.JavaProvider.invoke(JavaProvider.java:323) 在 org.apache.axis.strategies.InvocationStrategy.visit(InvocationStrategy.java:32) 在 org.apache.axis.SimpleChain.doVisiting(SimpleChain.java:118) 在 org.apache.axis.SimpleChain.invoke(SimpleChain.java:83) 在 org.apache.axis.handlers.soap.SOAPService.invoke(SOAPService.java:454) 在 org.apache.axis.server.AxisServer.invoke(AxisServer.java:281) 在 org.apache.axis.transport.http.AxisServlet.doPost(AxisServlet.java:699) 在 javax.servlet.http.HttpServlet.service(HttpServlet.java:641) 在 org.apache.axis.transport.http.AxisServletBase.service(AxisServletBase.java:327) 在 javax.servlet.http.HttpServlet.service(HttpServlet.java:722) 在 org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305) 在 org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 在 org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:224) 在 org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:169) 在 org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 在 org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168) 在 org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98) 在 org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:928) 在 org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 在 org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407) 在 org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:987) 在 org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:539) 在 org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:298) 在 java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) 在 java.lang.Thread.run(Thread.java:662)1 月 19 日编辑:
我还尝试按照@RakeshPatel 的建议将所有内容从 tomcat 7 迁移到 tomcat 6.0.35,但仍然遇到相同的异常。
我一直在阅读有关 InvocationTargetException 的信息,它包装了其他异常,因此,我在客户端捕获它并使用 getCause() 方法获取原因,但它返回 null。很奇怪,因为我调试了它,它似乎正在执行所有的 try 块,但它永远不会到达 return 语句。
有什么线索或建议吗?
【问题讨论】:
标签: java web-services soap axis jena