Ошибка созревания объекта Ksoap. Невозможно сериализовать: [[email protected]]

Можно ли отправить массив сложных объектов на сервер, я попробовал kvmSerializable интерфейс, по-прежнему получить не может сериализовать ошибку во время выполнения. Подробности и ошибка в logcat приведены ниже.

Часть файла wsdl, к которому я пытаюсь получить доступ, выглядит следующим образом














  










 


Ошибка в logcat следующая.

01-09 15:19:23.561: E/AndroidRuntime(1945): FATAL EXCEPTION: AsyncTask #2
01-09 15:19:23.561: E/AndroidRuntime(1945): java.lang.RuntimeException: An error  occured while executing doInBackground()
01-09 15:19:23.561: E/AndroidRuntime(1945):     at   android.os.AsyncTask$3.done(AsyncTask.java:278)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at   java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at java.util.concurrent.FutureTask.setException(FutureTask.java:124)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at java.util.concurrent.FutureTask.run(FutureTask.java:137)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:208)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at java.lang.Thread.run(Thread.java:856)
01-09 15:19:23.561: E/AndroidRuntime(1945): Caused by: java.lang.RuntimeException: Cannot serialize: [[email protected]]
01-09 15:19:23.561: E/AndroidRuntime(1945):     at org.ksoap2.serialization.SoapSerializationEnvelope.writeElement(SoapSerializationEnvelope.java:687)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at org.ksoap2.serialization.SoapSerializationEnvelope.writeProperty(SoapSerializationEnvelope.java:671)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at org.ksoap2.serialization.SoapSerializationEnvelope.writeObjectBody(SoapSerializationEnvelope.java:640)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at org.ksoap2.serialization.SoapSerializationEnvelope.writeElement(SoapSerializationEnvelope.java:683)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at org.ksoap2.serialization.SoapSerializationEnvelope.writeProperty(SoapSerializationEnvelope.java:671)
 01-09 15:19:23.561: E/AndroidRuntime(1945):    at org.ksoap2.serialization.SoapSerializationEnvelope.writeObjectBody(SoapSerializationEnvelope.java:640)
 01-09 15:19:23.561: E/AndroidRuntime(1945):    at  org.ksoap2.serialization.SoapSerializationEnvelope.writeObjectBody(SoapSerializationEnvelope.java:624)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at org.ksoap2.serialization.SoapSerializationEnvelope.writeElement(SoapSerializationEnvelope.java:681)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at org.ksoap2.serialization.SoapSerializationEnvelope.writeBody(SoapSerializationEnvelope.java:597)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at org.ksoap2.SoapEnvelope.write(SoapEnvelope.java:192)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at org.ksoap2.transport.Transport.createRequestData(Transport.java:101)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at org.ksoap2.transport.HttpTransportSE.call(HttpTransportSE.java:114)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at org.ksoap2.transport.HttpTransportSE.call(HttpTransportSE.java:90)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at com.example.inventory.Search$ShowDialogAsyncTask2.doInBackground(Search.java:89)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at com.example.inventory.Search$ShowDialogAsyncTask2.doInBackground(Search.java:1)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at android.os.AsyncTask$2.call(AsyncTask.java:264)
01-09 15:19:23.561: E/AndroidRuntime(1945):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
01-09 15:19:23.561: E/AndroidRuntime(1945):     ... 5 more    

Asynctask, который используется для использования веб-службы, выглядит следующим образом

private class ShowDialogAsyncTask2 extends AsyncTask {

@Override
protected SoapObject doInBackground(String... urls) {

    SoapObject request = new SoapObject(NAMESPACE, METHOD_NAME3);
   inventoryFilters = new ArrayList();
    filter = new InventoryFilter();
    rpd = new ResourcePageDetails();
    Object[] deviceTypes = { DeviceType.HOST };
    filter.setProperty(0, FilterType.DEVICE_TYPE);
    filter.setProperty(1, deviceTypes);

    inventoryFilters.add(0, filter);
    rpd.setProperty(0, 1);
    rpd.setProperty(1, 15);
    rpd.setProperty(2, inventoryFilters);

    request.addProperty("arg0",rpd);

    SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(SoapEnvelope.VER11);

    envelope.addMapping(NAMESPACE, "resourcePageDetails", ResourcePageDetails.class);
    envelope.addMapping(NAMESPACE, "InventoryFilter", InventoryFilter.class);
    envelope.addMapping(NAMESPACE, "Devicetype.HOST", DeviceType.class);
    envelope.addMapping(NAMESPACE, "FilterType.DEVICE_TYPE", FilterType.class);
    envelope.setOutputSoapObject(request);

    androidTransport = new HttpTransportSE(URL1);
     androidTransport.debug = true;

    try {
    androidTransport.call(SOAP_ACTION3, envelope);
    } catch (XmlPullParserException e) {
   //TODO Auto-generated catch block
    Log.d("xml", e.toString());
    e.printStackTrace();
    } catch (IOException e) {
   //TODO Auto-generated catch block
    e.printStackTrace();
    }
    Log.d("MyAPP", "----------------- " + androidTransport.requestDump + "\n\n"
        + androidTransport.responseDump);

    return soap;
}

@Override
protected void onPostExecute(SoapObject resultt) {
    super.onPostExecute(resultt);

}
}

Я пытаюсь решить эту проблему в течение последних 3 дней ... Но никакого успеха вообще. Если кто-то знает, как это решить, пожалуйста, помогите мне ..

2
добавлено отредактировано
Просмотры: 2
nl ja de
ваш InventoryFilter реализует сериализуемый интерфейс ???? Поскольку, когда вы хотите сериализовать объект, соответствующий класс должен реализовывать интерфейс -маркера serializable
добавлено автор BBdev, источник
Я не работал над KSOAP, но вы можете увидеть эту ссылку seesharpgears.blogspot .в/2010/11/& hellip;
добавлено автор BBdev, источник
Я думаю, вам тоже нужно показать код. Может быть, кто-то может сказать вам, в чем проблема.
добавлено автор BBdev, источник
Я ищу это решение также
добавлено автор meanbunny, источник
@BBdev да, на стороне сервера InventoryFilter реализует сериализуемое .... Знаете ли вы, что SoapSerializationEnvelope.writeElement, writeObject и т. Д. Означает?
добавлено автор Jinz..., источник
Спасибо, что опубликовали ссылку. Но я уже говорил об этом ... но не нашел ничего, что помогло бы решить проблему
добавлено автор Jinz..., источник
@BBdev я добавил asynctask, который я использовал для вызова webservice
добавлено автор Jinz..., источник

1 ответы

You have 2 objects: filter = new InventoryFilter(); and rpd = new ResourcePageDetails();, then you need to implements KvmSerializable interface from ksoap. You can use for your help these articles: java.lang.RuntimeException: Cannot serialize: MyClass and http://www.sgoliver.net/blog/?p=2594

0
добавлено