こんにちは、KSOAP2 2.6.2 Android アセンブリを使用して、glassfish 3.1.1 にデプロイされた Java WebService に接続しようとしています。私のアンドロイドプログラムから。ここに私の名前空間があります
public static final String SERVICE_NAMESPACE = "za.co.n7.mobilebackup";
public static final String SERVICE_URL = "http://ipaddress:8080/MobileBackupServiceImplService/MobileBackupServiceImpl/";
これが私の送信方法です
final String METHOD_NAME = "Login";
SoapObject results = null;
SoapObject request = null;
HttpTransportSE loginHttpTransport = null;
try {
request = new SoapObject(MBUtil.SERVICE_NAMESPACE, METHOD_NAME);
request.addProperty("username", username);
request.addProperty("password", MBUtil.hashPassword(password));
SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(
SoapEnvelope.VER11);
envelope.bodyOut=request;
envelope.enc = SoapSerializationEnvelope.ENC;
envelope.env="http://schemas.xmlsoap.org/soap/envelope/";
// Web method call
loginHttpTransport = new HttpTransportSE(MBUtil.SERVICE_URL);
loginHttpTransport.debug = true;
loginHttpTransport.call(MBUtil.SERVICE_URL + METHOD_NAME, envelope);
results = (SoapObject) envelope.getResponse();
System.out.println("Received Result without issue");
} catch (Exception e) {
e.printStackTrace();
System.out.println(loginHttpTransport.requestDump);
System.out.println(loginHttpTransport.responseDump);
} finally {
finish();
}
そして、DDMS LogCat で次のエラーが発生します。
04-08 15:30:42.508: W/System.err(1454): org.xmlpull.v1.XmlPullParserException: unexpected type (position:END_DOCUMENT null@1:0 in java.io.InputStreamReader@4056c7a8)
04-08 15:30:42.508: W/System.err(1454): at org.kxml2.io.KXmlParser.exception(KXmlParser.java:273)
04-08 15:30:42.508: W/System.err(1454): at org.kxml2.io.KXmlParser.nextTag(KXmlParser.java:1413)
04-08 15:30:42.508: W/System.err(1454): at org.ksoap2.SoapEnvelope.parse(SoapEnvelope.java:126)
04-08 15:30:42.508: W/System.err(1454): at org.ksoap2.transport.Transport.parseResponse(Transport.java:100)
04-08 15:30:42.519: W/System.err(1454): at org.ksoap2.transport.HttpTransportSE.call(HttpTransportSE.java:195)
04-08 15:30:42.519: W/System.err(1454): at org.ksoap2.transport.HttpTransportSE.call(HttpTransportSE.java:95)
04-08 15:30:42.519: W/System.err(1454): at za.co.n7.mobilebackup.LoginActivity.connect(LoginActivity.java:149)
04-08 15:30:42.519: W/System.err(1454): at za.co.n7.mobilebackup.LoginActivity$DoLoginRequest.run(LoginActivity.java:116)
04-08 15:30:42.519: W/System.err(1454): at android.os.Handler.handleCallback(Handler.java:587)
04-08 15:30:42.519: W/System.err(1454): at android.os.Handler.dispatchMessage(Handler.java:92)
04-08 15:30:42.519: W/System.err(1454): at android.os.Looper.loop(Looper.java:123)
04-08 15:30:42.519: W/System.err(1454): at android.app.ActivityThread.main(ActivityThread.java:3683)
04-08 15:30:42.519: W/System.err(1454): at java.lang.reflect.Method.invokeNative(Native Method)
04-08 15:30:42.519: W/System.err(1454): at java.lang.reflect.Method.invoke(Method.java:507)
04-08 15:30:42.519: W/System.err(1454): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
04-08 15:30:42.528: W/System.err(1454): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
04-08 15:30:42.528: W/System.err(1454): at dalvik.system.NativeStart.main(Native Method)
SOAP メッセージをコピーして soapUI に貼り付けたところ、結果が得られました。誰でも私を助けてくれますか、私はこれに何時間も苦労しています。これが私のSOAPメッセージのサンプルです
<v:Envelope xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns:d="http://www.w3.org/2001/XMLSchema" xmlns:c="http://schemas.xmlsoap.org/soap/encoding/" xmlns:v="http://schemas.xmlsoap.org/soap/envelope/">
<v:Header/>
<v:Body>
<n0:Login id="o0" c:root="1" xmlns:n0="za.co.n7.mobilebackup">
<username i:type="d:string">umohduke</username>
<password i:type="d:string">c4066ed69b81d6b2b25f76405195c83ddaeecd8dbd3866f17912b895a72bc059</password>
</n0:Login>
</v:Body>
</v:Envelope>