【问题标题】:EWS API Java : the request failed. nullEWS API Java:请求失败。空值
【发布时间】:2017-04-27 02:15:42
【问题描述】:

当我从 Web 服务调用 EWS Java API 时,出现错误。 完整的堆栈跟踪如下。 仅供参考,com.ixbat.synchroexchangews 是我们的网络服务。它调用一个 JAR (synchroexchange.*),后者调用 EWS API。

是否可以从其他 Web 服务调用 EWS API? 为什么会出现这个错误?

microsoft.exchange.webservices.data.core.exception.service.remote.ServiceRequestException: The request failed. null
at microsoft.exchange.webservices.data.core.request.SimpleServiceRequestBase.internalExecute(SimpleServiceRequestBase.java:74)
at microsoft.exchange.webservices.data.core.request.MultiResponseServiceRequest.execute(MultiResponseServiceRequest.java:158)
at microsoft.exchange.webservices.data.core.ExchangeService.internalCreateItems(ExchangeService.java:598)
at microsoft.exchange.webservices.data.core.ExchangeService.createItem(ExchangeService.java:657)
at microsoft.exchange.webservices.data.core.service.item.Item.internalCreate(Item.java:245)
at microsoft.exchange.webservices.data.core.service.item.Item.save(Item.java:386)
at synchroexchange.ExtendedTask.create(ExtendedTask.java:108)
at synchroexchange.ExchangeManager.wsPropagerAction(ExchangeManager.java:734)
at synchroexchange.ExchangeManager.wsPropagerAction(ExchangeManager.java:702)
at com.ixbat.synchroexchangews.SynchroExchangews.propagerAction(SynchroExchangews.java:152)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at weblogic.wsee.jaxws.WLSInstanceResolver$WLSInvoker.invoke(WLSInstanceResolver.java:117)
at weblogic.wsee.jaxws.WLSInstanceResolver$WLSInvoker.invoke(WLSInstanceResolver.java:91)
at com.sun.xml.ws.server.InvokerTube$2.invoke(InvokerTube.java:149)
at com.sun.xml.ws.server.sei.SEIInvokerTube.processRequest(SEIInvokerTube.java:88)
at com.sun.xml.ws.api.pipe.Fiber.__doRun(Fiber.java:1136)
at com.sun.xml.ws.api.pipe.Fiber._doRun(Fiber.java:1050)
at com.sun.xml.ws.api.pipe.Fiber.doRun(Fiber.java:1019)
at com.sun.xml.ws.api.pipe.Fiber.runSync(Fiber.java:877)
at com.sun.xml.ws.server.WSEndpointImpl$2.process(WSEndpointImpl.java:419)
at com.sun.xml.ws.transport.http.HttpAdapter$HttpToolkit.handle(HttpAdapter.java:868)
at com.sun.xml.ws.transport.http.HttpAdapter.handle(HttpAdapter.java:422)
at com.sun.xml.ws.transport.http.servlet.ServletAdapter.handle(ServletAdapter.java:169)
at weblogic.wsee.jaxws.WLSServletAdapter.handle(WLSServletAdapter.java:199)
at weblogic.wsee.jaxws.HttpServletAdapter$AuthorizedInvoke.run(HttpServletAdapter.java:640)
at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:363)
at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:146)
at weblogic.wsee.util.ServerSecurityHelper.authenticatedInvoke(ServerSecurityHelper.java:108)
at weblogic.wsee.jaxws.HttpServletAdapter$3.run(HttpServletAdapter.java:284)
at weblogic.wsee.jaxws.HttpServletAdapter.post(HttpServletAdapter.java:293)
at weblogic.wsee.jaxws.JAXWSServlet.doRequest(JAXWSServlet.java:128)
at weblogic.servlet.http.AbstractAsyncServlet.service(AbstractAsyncServlet.java:99)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:844)
at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:280)
at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:254)
at weblogic.servlet.internal.StubSecurityHelper.invokeServlet(StubSecurityHelper.java:136)
at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:346)
at weblogic.servlet.internal.TailFilter.doFilter(TailFilter.java:25)
at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:79)
at oracle.security.jps.ee.http.JpsAbsFilter$1.run(JpsAbsFilter.java:137)
at java.security.AccessController.doPrivileged(Native Method)
at oracle.security.jps.util.JpsSubject.doAsPrivileged(JpsSubject.java:315)
at oracle.security.jps.ee.util.JpsPlatformUtil.runJaasMode(JpsPlatformUtil.java:460)
at oracle.security.jps.ee.http.JpsAbsFilter.runJaasMode(JpsAbsFilter.java:120)
at oracle.security.jps.ee.http.JpsAbsFilter.doFilter(JpsAbsFilter.java:217)
at oracle.security.jps.ee.http.JpsFilter.doFilter(JpsFilter.java:81)
at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:79)
at oracle.dms.servlet.DMSServletFilter.doFilter(DMSServletFilter.java:220)
at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:79)
at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.wrapRun(WebAppServletContext.java:3436)
at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3402)
at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)
at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:120)
at weblogic.servlet.provider.WlsSubjectHandle.run(WlsSubjectHandle.java:57)
at weblogic.servlet.internal.WebAppServletContext.doSecuredExecute(WebAppServletContext.java:2285)
at weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:2201)
at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:2179)
at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1572)
at weblogic.servlet.provider.ContainerSupportProviderImpl$WlsRequestExecutor.run(ContainerSupportProviderImpl.java:255)
at weblogic.work.ExecuteThread.execute(ExecuteThread.java:311)
at weblogic.work.ExecuteThread.run(ExecuteThread.java:263)
Caused by: java.lang.NullPointerException
at com.ctc.wstx.sw.BaseStreamWriter.writeCharacters(BaseStreamWriter.java:451)
at microsoft.exchange.webservices.data.core.EwsServiceXmlWriter.writeValue(EwsServiceXmlWriter.java:307)
at microsoft.exchange.webservices.data.property.complex.StringList.writeElementsToXml(StringList.java:117)
at microsoft.exchange.webservices.data.property.complex.ComplexProperty.writeToXml(ComplexProperty.java:325)
at microsoft.exchange.webservices.data.property.complex.ComplexProperty.writeToXml(ComplexProperty.java:338)
at microsoft.exchange.webservices.data.property.definition.ComplexPropertyDefinitionBase.writePropertyValueToXml(ComplexPropertyDefinitionBase.java:170)
at microsoft.exchange.webservices.data.core.PropertyBag.writeToXml(PropertyBag.java:548)
at microsoft.exchange.webservices.data.core.service.ServiceObject.writeToXml(ServiceObject.java:321)
at microsoft.exchange.webservices.data.core.request.CreateRequest.writeElementsToXml(CreateRequest.java:129)
at microsoft.exchange.webservices.data.core.request.ServiceRequestBase.writeBodyToXml(ServiceRequestBase.java:134)
at microsoft.exchange.webservices.data.core.request.ServiceRequestBase.writeToXml(ServiceRequestBase.java:256)
at microsoft.exchange.webservices.data.core.request.ServiceRequestBase.buildEwsHttpWebRequest(ServiceRequestBase.java:696)
at microsoft.exchange.webservices.data.core.request.ServiceRequestBase.buildEwsHttpWebRequest(ServiceRequestBase.java:665)
at microsoft.exchange.webservices.data.core.request.ServiceRequestBase.validateAndEmitRequest(ServiceRequestBase.java:635)
at microsoft.exchange.webservices.data.core.request.SimpleServiceRequestBase.internalExecute(SimpleServiceRequestBase.java:62)
... 63 more

感谢您的帮助

【问题讨论】:

  • 我不明白问题是什么。您只是想知道堆栈跟踪的原因还是其他原因?请参阅 SO 提问指南 (stackoverflow.com/help/how-to-ask)。
  • 是的,我想知道为什么会出现这个错误。我编辑主帖。
  • 酷。由于您编辑了帖子,因此我删除了反对票。

标签: java web-services api exchangewebservices


【解决方案1】:

在没有看到实际代码的情况下,我无法确定,但我会根据您的堆栈跟踪推测您正在向 Web 服务发送请求,但是当它正在编组 XML 时,其中一个字段为空,所以它抛出了这个异常。我鼓励您调试并确定您尝试发送的任何字段是否确实丢失了。

【讨论】:

  • 其实这个bug来自第74行:github.com/OfficeDev/ews-java-api/blob/master/src/main/java/…。这很奇怪,因为当我“正常”调用相同的方法创建时它运行良好。但是当我从另一个网络服务调用它时,它不起作用。知道网络服务是否可以调用另一个网络服务吗?
  • 我怀疑正在发生的事情是,在您“通常”调用该方法的上下文中,此 Web 服务实际上正在运行一些内部设置代码,该代码将自身置于正确状态,该代码用于调用下游服务。但是,当您从另一个 Web 服务调用时,中间 Web 服务不会将自己置于正确的状态并运行必要的初步代码。我唯一能说的是调试两条路径以弄清楚发生了什么,这可能需要一段时间。 :-/
  • 至于你的问题,绝对! Web 服务的主要优势之一是它们的行为类似于函数,因为它们可以根据需要相互调用。
猜你喜欢
  • 2016-08-15
  • 2016-06-28
  • 2021-11-04
  • 2012-08-13
  • 1970-01-01
  • 1970-01-01
  • 2013-11-09
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多