Android AsyncTask Проблема с SoapObject
Я хочу использовать.net веб-сервис в моем приложении для Android. Я отправляю запрос на веб-сервис, используя asynctask. Но запрос не имеет значения должным образом. Я использовал эту структуру во многих приложениях для Android, и у меня никогда не возникало таких ошибок. В чем проблема?
У меня есть разрешение (ИНТЕРНЕТ). Пространство имен и имя метода имеют значение true.
public class MainActivity extends Activity {
private static final String NAMESPACE = "http://tempuri.org/";
private static final String URL = "http://service.melihmucuk.com/ShopArWS.asmx";
private String[][] items;
private String[][] GetAllItems(){
SoapObject request = new SoapObject(NAMESPACE, "GetAllItem");//faulty line
SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(SoapEnvelope.VER11);
envelope.dotNet = true;
envelope.setOutputSoapObject(request);
HttpTransportSE androidHttpTransport = new HttpTransportSE(URL);
androidHttpTransport.debug = true;
try {
androidHttpTransport.call("http://tempuri.org/GetAllItem", envelope);
SoapObject response = (SoapObject) envelope.getResponse();
items[0] = new String[response.getPropertyCount()]; //item_id
items[1] = new String[response.getPropertyCount()]; //price
items[2] = new String[response.getPropertyCount()]; //title
items[3] = new String[response.getPropertyCount()]; //desc
for(int i=0;i<response.getPropertyCount();i++){
Object property = response.getProperty(i);
if(property instanceof SoapObject){
SoapObject item = (SoapObject) property;
String item_id = item.getProperty("item_id").toString();
String price = item.getProperty("price").toString();
String title = item.getProperty("title").toString();
String desc = item.getProperty("desc").toString();
items[0][i] = item_id;
items[1][i] = price;
items[2][i] = title;
items[3][i] = desc;
}
}
}
catch (Exception e) {
e.printStackTrace();
}
return items;
}
public class GetAllItemsAS extends AsyncTask<String,String,String[][]>{
@Override
protected void onPreExecute() {
}
@Override
protected String[][] doInBackground(String... params) {
GetAllItems();
return items;
}
protected void onPostExecute(String[][] items){
ASFinish();
}
}
public void ASFinish(){
ListView liste = (ListView)findViewById(R.id.listView1);
ListArrayAdapter adapter = new ListArrayAdapter(MainActivity.this,items[0],items[1],items[2],items[3]);
liste.setAdapter(adapter);
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
items = new String[4][0];
new GetAllItemsAS().execute();
}
}
Мой LogCat
05-22 01:07:10.201: E/WindowManager(22337): Activity com.zontul.shopar.MainActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@414ba3a0 that was originally added here
05-22 01:07:10.201: E/WindowManager(22337): android.view.WindowLeaked: Activity com.zontul.shopar.MainActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@414ba3a0 that was originally added here
05-22 01:07:10.201: E/WindowManager(22337): at android.view.ViewRootImpl.<init>(ViewRootImpl.java:464)
05-22 01:07:10.201: E/WindowManager(22337): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:419)
05-22 01:07:10.201: E/WindowManager(22337): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:351)
05-22 01:07:10.201: E/WindowManager(22337): at android.view.WindowManagerImpl$CompatModeWrapper.addView(WindowManagerImpl.java:171)
05-22 01:07:10.201: E/WindowManager(22337): at android.view.Window$LocalWindowManager.addView(Window.java:558)
05-22 01:07:10.201: E/WindowManager(22337): at android.app.Dialog.show(Dialog.java:282)
05-22 01:07:10.201: E/WindowManager(22337): at com.zontul.shopar.MainActivity$GetAllItemsAS.onPreExecute(MainActivity.java:78)
05-22 01:07:10.201: E/WindowManager(22337): at android.os.AsyncTask.executeOnExecutor(AsyncTask.java:586)
05-22 01:07:10.201: E/WindowManager(22337): at android.os.AsyncTask.execute(AsyncTask.java:534)
05-22 01:07:10.201: E/WindowManager(22337): at com.zontul.shopar.MainActivity.onCreate(MainActivity.java:115)
05-22 01:07:10.201: E/WindowManager(22337): at android.app.Activity.performCreate(Activity.java:5066)
05-22 01:07:10.201: E/WindowManager(22337): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1101)
05-22 01:07:10.201: E/WindowManager(22337): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2311)
05-22 01:07:10.201: E/WindowManager(22337): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2391)
05-22 01:07:10.201: E/WindowManager(22337): at android.app.ActivityThread.access$600(ActivityThread.java:151)
05-22 01:07:10.201: E/WindowManager(22337): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1335)
05-22 01:07:10.201: E/WindowManager(22337): at android.os.Handler.dispatchMessage(Handler.java:99)
05-22 01:07:10.201: E/WindowManager(22337): at android.os.Looper.loop(Looper.java:155)
05-22 01:07:10.201: E/WindowManager(22337): at android.app.ActivityThread.main(ActivityThread.java:5520)
05-22 01:07:10.201: E/WindowManager(22337): at java.lang.reflect.Method.invokeNative(Native Method)
05-22 01:07:10.201: E/WindowManager(22337): at java.lang.reflect.Method.invoke(Method.java:511)
05-22 01:07:10.201: E/WindowManager(22337): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1029)
05-22 01:07:10.201: E/WindowManager(22337): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:796)
05-22 01:07:10.201: E/WindowManager(22337): at dalvik.system.NativeStart.main(Native Method)
Редактировать: я редактировал свой код, и я не использую диалог. Пожалуйста, не пишите ответ о диалоге. Проблема не возникает в диалоге.
3 ответа
Актуальная проблема в методе GetAllItems(), он генерирует исключение, которое объясняет, почему действие будет завершено, и после этого вы пытаетесь показать диалоговое окно хода выполнения, сделав одну вещь, которая помещает попытку try в GetAllItems() и пытается запустите этот код в doInBackground.
Вам нужно будет инициализировать ProgressDialog
внутри onPreExecute
вместо на уровне класса:
private ProgressDialog dialog; //declare here
@Override
protected void onPreExecute() {
dialog = new ProgressDialog(MainActivity.this); //<< initialize here
dialog.setMessage("Loading...");
dialog.show();
}
//.....
protected void onPostExecute(String[][] items){
ASFinish();
if(null !=dialog)
if(dialog.isShowing())
dialog.dismiss();
}
Ошибка в том, что на вашем AsynTask
и dialog
Привязанный к этому действию не был отклонен, он активирует исключение, которое вы опубликовали.
Кстати, если вы хотите остановить AsynTask
если деятельность уничтожена, помните
- Отмените Asyntask в
onDestroy
, - Если
AsynTask
отменяется переопределитьonCancelled
функционировать и проверить состояние наdoinBackground
чтобы завершить задачу как можно скорее. - В
onCancelled
также отклонить диалог.
В противном случае ваша активность может быть уничтожена до onPostExecute, и для этой функции будет активировано исключение.
Задача может быть отменена в любое время, вызвав отмена (булево). Вызов этого метода приведет к тому, что последующие вызовы isCancelled() вернут true. После вызова этого метода onCancelled(Object) вместо onPostExecute(Object) будет вызываться после возврата doInBackground(Object[]). Чтобы отменить задачу как можно быстрее, всегда следует периодически проверять возвращаемое значение isCancelled() из doInBackground(Object[]), если это возможно (например, внутри цикла.)