WCF .Net 4.0 Client Ошибка в десериализации тела ответного сообщения - PullRequest
1 голос
/ 20 июля 2010

Я пытаюсь заставить клиента WCF .Net 4.0 работать с веб-службой NuSOAP / 0.7.2 (1.94). Во-первых, веб-сервис не основан на текущих стандартах SOA, поэтому мне пришлось создать собственный кодировщик для обработки сообщений ISO-8859-1. Когда я получаю ответ, WCF выдает следующее исключение

«Ошибка десериализации тела ответного сообщения»

При взгляде на тело SOAP я вижу <SOAP-ENV:Body>... stream ...</SOAP-ENV:Body>

Кто-нибудь сталкивался с этой ошибкой? Любая обратная связь или точка в правильном направлении будет принята с благодарностью. Это мой первый WCF для "не" службы WCF.

ApplicationData
TraceData
<DataItem>
<MessageLogTraceRecord Time="2010-07-14T19:14:36.4832868-07:00" Source="TransportReceive" Type="System.ServiceModel.Channels.StreamedMessage" xmlns="http://schemas.microsoft.com/2004/06/ServiceModel/Management/MessageTrace">
<HttpResponse>
<StatusCode>OK</StatusCode>
<StatusDescription>OK</StatusDescription>
<WebHeaders>
<X-SOAP-Server>NuSOAP/0.7.2 (1.94)</X-SOAP-Server>
<Content-Encoding></Content-Encoding>
<Content-Length>496</Content-Length>
<Content-Type>text/xml; charset=ISO-8859-1</Content-Type>
<Date>Thu, 15 Jul 2010 02:14:36 GMT</Date>
<Server>Apache/2.0.54 (Unix) mod_ssl/2.0.54 OpenSSL/0.9.7a PHP/4.3.11</Server>
<X-Powered-By>PHP/4.3.11</X-Powered-By>
</WebHeaders>
</HttpResponse>
<SOAP-ENV:Envelope SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:SOAP-ENC="http://schemas.xmlsoap.org/soap/encoding/" xmlns:tns="https://www.datatranswebedi.com/soapv2/">
<SOAP-ENV:Header></SOAP-ENV:Header>
<SOAP-ENV:Body>... stream ...</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
</MessageLogTraceRecord>
</DataItem>
</TraceData>
</ApplicationData>

Спасибо заранее, Бреннан

Ответы [ 2 ]

2 голосов
/ 26 июля 2010

Оказывается, произошла ошибка при десериализации даты, потому что она была не в правильном формате. Я обнаружил ошибку, включив режим подробного отладки в клиенте WCF.

System.InvalidCastException: Невозможно назначить объект типа System.Xml.XmlNode [] объекту типа System.DateTime.

Устаревший веб-сервис возвращал «xsd: date» с датой и временем, когда тип данных должен был быть «xsd: dateTime».

Чтобы подтвердить, что это было причиной проблемы, я запросил две записи у веб-службы и манипулировал XML в переопределенном методе Message ReadMessage () и изменил автоматически сгенерированный прокси-класс. Это исправило проблему, и я знаю, что это не окончательное решение. Прежде чем я свяжусь с автором устаревшего веб-сервиса, есть ли у кого-нибудь какие-либо комментарии по поводу формата Soap date и dateTime?

Maybe the following date is valid in Soap Version 1.1 with ISO-8859-1 encoding:

<date xsi:type="xsd:date">2010-05-02 08:03:45</date>

 If it is, is this an issue using a custom encoder or was it really the date type/format in the soap body? Microsoft only accepted that date in the following format:

<date xsi:type="xsd:dateTime">2010-05-02T08:03:45</date>


    <customBinding>
      <binding name="ISO8859Binding">
        <customTextMessageEncoding messageVersion="Soap11" encoding="ISO-8859-1" mediaType="text/xml"  />
        <httpsTransport />
      </binding>
      </customBinding>

public override Message ReadMessage(Stream stream, int maxSizeOfHeaders, string contentType)
{

    XmlReader reader = XmlReader.Create(stream);
    XmlDocument doc = new XmlDocument();

    // Log to a file.
    StreamWriter sw = new StreamWriter(@"C:\dump2.txt");

    doc.Load(reader);
    doc.InnerXml = doc.InnerXml.Replace("xsd:date", "xsd:dateTime");
    doc.InnerXml = doc.InnerXml.Replace("2010-05-02 08:03:45", "2010-05-02T08:03:45");
    doc.InnerXml = doc.InnerXml.Replace("2010-05-02 12:38:06", "2010-05-02T12:38:06");

    sw.WriteLine(doc.InnerXml);
    sw.Flush();
    sw.Close();

    byte[] buffer = System.Text.Encoding.Default.GetBytes(doc.InnerXml);
    Stream test = new MemoryStream(buffer);
    XmlReader reader2 = XmlReader.Create(test);

    return Message.CreateMessage(reader2, maxSizeOfHeaders, this.MessageVersion);

}

Еще раз спасибо, Бреннан

1 голос
/ 20 июля 2010

Мне пришлось сделать то же самое (с другим веб-сервисом устаревшего типа), и я сначала столкнулся с проблемами.

Я наткнулся на этот отличный пост в блоге WCF: Кодировка текстовых сообщений и ISO-8859-1 Кодировка , которая описывает несколько ловушек при реализации пользовательского кодировщика текста для WCF - может быть, это будет вам полезно?

Также ознакомьтесь с предыдущим вопросом Stackoverflow по той же теме:

Вызов веб-службы, использующей кодировку ISO-8859-1 из WCF

...