javax.xml.soap.MessageFactory.createMessage调用对于大型内容花费的时间太长

时间:2020-06-17 22:43:14

标签: soap javax.xml

http响应内容是一条内容为100mb的肥皂消息。

messageFactory.createMessage(null,responseinputstream) 需要3到4分钟, responseSoapMessage.getSOAPBody() 再花4分钟或更长时间。 之后,由于我在WildFly应用服务器中,因此事务超时。

MessageFactory messageFactory = MessageFactory.newInstance(SOAPConstants.SOAP_1_2_PROTOCOL);
...
HttpEntity responseHttpEntity = httpResponse.getEntity();
...
InputStream responseContentStream = responseHttpEntity.getContent();
SOAPMessage responseSoapMessage = messageFactory.createMessage(null, responseContentStream);
SOAPBody responseSoapBody = responseSoapMessage.getSOAPBody();

在通过MessageFactory从InputStream创建SOAPMessage时,我想知道为什么要花这么长时间。

可能是由于某些JAR问题引起的吗? 我在玩两个JARS:axis-1.4.jar和saaj-impl-1.3.jar

但是,在调试时,我发现使用的类是saaj-impl-1.3.jar中的SOAPMessageFactory1_2Impl。

不过,我无法解释为什么要花超过5分钟的时间来跨越这两行代码。

这是响应InputStream中的SOAP XML。

<soap:Envelope xmlns:soap="http://www.w3.org/2003/05/soap-envelope" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
   <soap:Body>
      <ReceiveDocumentResponse xmlns="https://NAMESPACEURL">
         <ReceiveDocumentResult>
            <base64Binary>HERE IS THE JPG IMAGE CONTENT OF SIZE 100 MB OR MORE</base64Binary>
         </ReceiveDocumentResult>
      </ReceiveDocumentResponse>
   </soap:Body>
</soap:Envelope>

注意,对于少于30 MB的内容,此方法调用工作正常(快速)。

任何有关故障排除的技巧,或任何其他用于解析内容的技巧,都非常感谢

1 个答案:

答案 0 :(得分:0)

我用下面的内容代替了上面的逻辑。 100 MB的内容确实需要花费一分钟左右的时间,但是仍然可以正常工作。

DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance(); 
builderFactory.setNamespaceAware(true);
DocumentBuilder domParser = null;
                    
domParser = builderFactory.newDocumentBuilder();
domDocument =  domParser.parse(responseContentStream);
NodeList elementList = domDocument.getElementsByTagName("base64Binary");
Node element = elementList.item(0);
String base64String = element.getTextContent();
byte[]  rawData= Base64.getDecoder().decode(base64String);
document.setBData(rawData);

无论是什么...