Ось: faultString: org.xml.sax.SAXParseException: преждевременное завершение файла - PullRequest
0 голосов
/ 06 октября 2009

Я развернул веб-сервис, используя servletexec, настроенный на IIS, и могу успешно получить доступ к веб-сервису, используя анонимную учетную запись. Но когда я включаю встроенную аутентификацию Windows, я получаю следующую ошибку.

  - ntlm authentication scheme selected
- Discarding unexpected response: HTTP/1.1 100 Continue
AxisFault
 faultCode: {http://schemas.xmlsoap.org/soap/envelope/}Server.userException
 faultSubcode: 
 faultString: org.xml.sax.SAXParseException: Premature end of file.
 faultActor: 
 faultNode: 
 faultDetail: 
    {http://xml.apache.org/axis/}hostname:akvm

org.xml.sax.SAXParseException: Premature end of file.
    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 com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.endElement(AbstractSAXParser.java:633)
    at com.sun.org.apache.xerces.internal.impl.XMLNSDocumentScannerImpl.scanEndElement(XMLNSDocumentScannerImpl.java:719)
    at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl$FragmentContentDispatcher.dispatch(XMLDocumentFragmentScannerImpl.java:1685)
    at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(XMLDocumentFragmentScannerImpl.java:368)
    at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:834)
    at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:764)
    at com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(XMLParser.java:148)
    at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.parse(AbstractSAXParser.java:1242)
    at javax.xml.parsers.SAXParser.parse(SAXParser.java:375)
    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)

Ответы [ 2 ]

1 голос
/ 18 ноября 2011

Похоже, что клиенту Axis не нравится проверка подлинности NTLM. См. Сообщение об ошибке вверху:

Discarding unexpected response: HTTP/1.1 100 Continue

После чего Axis не может выполнить синтаксический анализ XML, поэтому вы получаете преждевременный конец файла.

Чтобы использовать NTLM с Axis (1.4), вам придется использовать CommonsHTTPSender вместо стандартного транспорта:

<transport name="http" pivot="java:org.apache.axis.transport.http.CommonsHTTPSender">
</transport>

в вашем client-config.wsdd, а затем настройте имя пользователя и пароль NTLM через объект Stub.

0 голосов
/ 08 октября 2009

Ошибки типа «преждевременный конец файла» из реализации xerces SAX обычно указывают на то, что анализатор SAX ожидал данные, но не получил ни одного (не null, а инициализированный пустой InputSource). Из трассировки стека это выглядит так, как будто обработчик оси SOAP ожидает поступления сообщения SOAP xml, но это сообщение пустое. Мои знания ISS и его инфраструктуры близки к нулю, вы можете получить какие-либо сообщения журнала с сервера?

...