SOAP の出力を解析する方法を知りたいです。私の現在のコードは次のとおりです。
try{
SoapObject request = new SoapObject(NAMESPACE, METHOD_NAME);
SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(SoapEnvelope.VER11);
envelope.setOutputSoapObject(request);
HttpTransportSE androidHttpTransport = new HttpTransportSE(URL);
androidHttpTransport.call(SOAP_ACTION, envelope);
Object response = (Object) envelope.getResponse();
Log.e("Output:", response.toString());
}catch (Exception e){
Log.e("Error:", e.getCause().toString());
}
応答の出力は次のとおりです。
[{"category_id":767,"parent_id":663,"name":"Walk"}, {"category_id":768,"parent_id":767,"name":"Google"}, {"category_id": 764,"parent_id":697,"名前":"黄色"}]
では、これらの値を個別に取得するにはどうすればよいでしょうか。
この行を変更すると、次のようになります。
Object response = (Object) envelope.getResponse();
これに:
SoapObject response = (SoapObject) envelope.getResponse();
次のエラーが表示されます。
10-01 11:28:08.086: E/AndroidRuntime(4600): FATAL EXCEPTION: main
10-01 11:28:08.086: E/AndroidRuntime(4600): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.WebExample/com.example.WebExample.SyncActivity}: java.lang.NullPointerException
10-01 11:28:08.086: E/AndroidRuntime(4600): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2211)
10-01 11:28:08.086: E/AndroidRuntime(4600): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
10-01 11:28:08.086: E/AndroidRuntime(4600): at android.app.ActivityThread.access$600(ActivityThread.java:141)
10-01 11:28:08.086: E/AndroidRuntime(4600): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
10-01 11:28:08.086: E/AndroidRuntime(4600): at android.os.Handler.dispatchMessage(Handler.java:99)
10-01 11:28:08.086: E/AndroidRuntime(4600): at android.os.Looper.loop(Looper.java:137)
10-01 11:28:08.086: E/AndroidRuntime(4600): at android.app.ActivityThread.main(ActivityThread.java:5103)
10-01 11:28:08.086: E/AndroidRuntime(4600): at java.lang.reflect.Method.invokeNative(Native Method)
10-01 11:28:08.086: E/AndroidRuntime(4600): at java.lang.reflect.Method.invoke(Method.java:525)
10-01 11:28:08.086: E/AndroidRuntime(4600): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
10-01 11:28:08.086: E/AndroidRuntime(4600): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
10-01 11:28:08.086: E/AndroidRuntime(4600): at dalvik.system.NativeStart.main(Native Method)
10-01 11:28:08.086: E/AndroidRuntime(4600): Caused by: java.lang.NullPointerException
10-01 11:28:08.086: E/AndroidRuntime(4600): at
com.example.WebExample.SyncActivity.onCreate(SyncActivity.java:49)
10-01 11:28:08.086: E/AndroidRuntime(4600): at android.app.Activity.performCreate(Activity.java:5133)
10-01 11:28:08.086: E/AndroidRuntime(4600): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
10-01 11:28:08.086: E/AndroidRuntime(4600): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2175)
10-01 11:28:08.086: E/AndroidRuntime(4600): ... 11 more
ありがとう。