Я разрабатываю клиент Android для службы WCF. Существует приложение для Windows, которое работает с сервисом без каких-либо проблем. Однако, когда я пытаюсь использовать сервис на Android, используя kSoap2 - я получаю 500 Internal Server Error. Очевидно, я делаю что-то не так, но не могу понять, что.
Вот мой код Java:
// SOAP consts
private static final String NAMESPACE = "http://tempuri.org/";
private static final String SERVICE_NAME = "/SignService";
private static final String SOAP_ACTION = "http://tempuri.org/ISignService/";
...
String url;
String method_name = "GetExistedSignData";
url = mServerAddress + SERVICE_NAME;
/* the connect logic goes here */
try {
SoapObject request = new SoapObject(NAMESPACE, method_name);
request.addProperty("displayId", "HWI_00:1E:8C:87:7F:8D");
SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(SoapEnvelope.VER12);
envelope.dotNet = true;
//envelope.implicitTypes = true;
envelope.setAddAdornments(false);
envelope.setOutputSoapObject(request);
HttpTransportSE androidHttpTransport = new HttpTransportSE(url);
androidHttpTransport.call(method_name, envelope);
sb.append(envelope.toString() + "\n");
SoapPrimitive result = (SoapPrimitive)envelope.getResponse();
//to get the data
String resultData = result.toString();
sb.append(resultData + "\n");
} catch (IOException e) {
sb.append("IO Problem:\n" + e.getMessage() + "\n");
} catch (XmlPullParserException e) {
sb.append("Parser Problem:\n" + e.getMessage() + "\n");
}
catch (Exception e) {
sb.append("Error:\n" + e.getMessage() + "\n");
}
Вот HTTP-дамп Windows-клиента, успешно вызвавшего метод:
POST /SignService HTTP/1.1
Content-Type: application/soap+xml; charset=utf-8
Host: ariadnetest.ariadne.vn
Content-Length: 995
Connection: Keep-Alive
<?xml version="1.0"?>
<s:Envelope xmlns:s="http://www.w3.org/2003/05/soap-envelope" xmlns:r="http://schemas.xmlsoap.org/ws/2005/02/rm" xmlns:a="http://www.w3.org/2005/08/addressing">
<s:Header>
<r:Sequence s:mustUnderstand="1">
<r:Identifier>urn:uuid:b6073cc9-d142-4045-90cb-1ae8d839d400</r:Identifier>
<r:MessageNumber>1</r:MessageNumber>
</r:Sequence>
<a:Action s:mustUnderstand="1">http://tempuri.org/ISignService/GetExistedSignData</a:Action>
<a:MessageID>urn:uuid:ad89a2da-6205-460b-b50c-9b354d83594d</a:MessageID>
<ActivityId xmlns="http://schemas.microsoft.com/2004/09/ServiceModel/Diagnostics" CorrelationId="9c91571d-e363-45da-ab5b-a83d48f3ec82">468b8556-f549-4d1f-969a-591aae05d4af</ActivityId>
<a:ReplyTo>
<a:Address>http://www.w3.org/2005/08/addressing/anonymous</a:Address>
</a:ReplyTo>
<a:To s:mustUnderstand="1">http://ariadnetest.ariadne.vn/SignService</a:To>
</s:Header>
<s:Body>
<GetExistedSignData xmlns="http://tempuri.org/">
<displayId>HWI_00:1E:8C:87:7F:8D</displayId>
</GetExistedSignData>
</s:Body>
</s:Envelope>
Вот дамп HTTP моего неудачного вызова того же метода:
POST /SignService HTTP/1.1
User-Agent: ksoap2-android/2.6.0+
Content-Type: application/soap+xml;charset=utf-8
Connection: close
Content-Length: 358
Host: ariadnetest.ariadne.vn
Accept-Encoding: gzip
<?xml version="1.0"?>
<v:Envelope xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns:d="http://www.w3.org/2001/XMLSchema" xmlns:c="http://www.w3.org/2003/05/soap-encoding" xmlns:v="http://www.w3.org/2003/05/soap-envelope">
<v:Header/>
<v:Body>
<GetExistedSignData xmlns="http://tempuri.org/">
<displayId>HWI_00:1E:8C:87:7F:8D</displayId>
</GetExistedSignData>
</v:Body>
</v:Envelope>
В ответ я получаю:
HTTP/1.0 500 Internal Server Error
Date: Tue, 13 Dec 2011 15:46:07 GMT
Pragma: no-cache
Cache-Control: no-cache
Content-Type: text/html
Content-Length: 2114
Connection: close
Самая полезная часть описания ошибки гласит:
Error Code 64: Host not available
Background: The connection to the Web server was lost.
Я не очень знаком с WCF и .NET, поэтому у меня нет вариантов того, что может быть не так. Я не разработал службу WCF, которую мне нужно использовать в Android.