0

私は初心者なので、我慢してください。

Webサービスから自分の近くの最も近い場所をプルする非同期タスクがあります。2.1以降の新しいAndroidデバイスで正常に動作します。2.1のHTCヒーローがいますが、ボタンを押してデータを見つけるたびにクラッシュします。

これが私が持っているコードです。最初の部分は、デバイスからlatとlongを取得し、サーバー上で作成したphpスクリプトに送信します。

    private class DownloadWebPageTask extends AsyncTask<String, Void, String> {
    @Override
    protected String doInBackground(String... urls) {
        //String response = "";
        for (String url : urls) {
            HttpClient httpclient = new DefaultHttpClient();
            HttpPost httppost = new HttpPost(url);
            try {
                // Add your data
                List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(2);
                nameValuePairs.add(new BasicNameValuePair("lat", lat));
                nameValuePairs.add(new BasicNameValuePair("long", longit));
                httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
                // Execute HTTP Post Request
                UrlEncodedFormEntity ent = new UrlEncodedFormEntity(nameValuePairs,
                        HTTP.UTF_8);
                httppost.setEntity(ent);
                HttpResponse responsePOST = httpclient.execute(httppost);
                responseBody = EntityUtils.toString(responsePOST.getEntity());
                Log.i("YAhh", responseBody);
            } catch (ClientProtocolException e) {
                // TODO Auto-generated catch block
            } catch (IOException e) {
                // TODO Auto-generated catch block
            }
        }
        return responseBody;
        }

この部分は、データを別のアクティビティに送信して、解析してリストビューに表示します。

  @Override
    protected void onPostExecute(String result) {
        Log.i("returndata",responseBody);
    /*  Intent intent = new Intent(HomeActivity.this,
                locationActivity.class);
        Bundle bundle = new Bundle();
        bundle.putString("returnBody", responseBody);
        bundle.putString("latit", lat);
        bundle.putString("longit" + "", longit);
        intent.putExtras(bundle);
        startActivity(intent);*/
    }
}

これは私が受け取っているエラーです。データが返されていないため、null値がエラーの原因であることがわかります。

  08-02 15:17:13.848: E/AndroidRuntime(1117): Uncaught handler: thread main exiting due to uncaught   exception
  08-02 15:17:13.968: E/AndroidRuntime(1117): java.lang.NullPointerException: println needs a message
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at android.util.Log.println(Native Method)
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at android.util.Log.i(Log.java:136)
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at com.mlgw.mlgwapp.HomeActivity$DownloadWebPageTask.onPostExecute(HomeActivity.java:278)
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at   com.mlgw.mlgwapp.HomeActivity$DownloadWebPageTask.onPostExecute(HomeActivity.java:1)
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at android.os.AsyncTask.finish(AsyncTask.java:417)
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at android.os.AsyncTask.access$300(AsyncTask.java:127)
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:429)
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at android.os.Handler.dispatchMessage(Handler.java:99)
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at android.os.Looper.loop(Looper.java:123)
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at android.app.ActivityThread.main(ActivityThread.java:4595)
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at java.lang.reflect.Method.invokeNative(Native Method)
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at java.lang.reflect.Method.invoke(Method.java:521)
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
  08-02 15:17:13.968: E/AndroidRuntime(1117):   at dalvik.system.NativeStart.main(Native Method)

なぜこれが2.1で機能しないのかについて誰かが手がかりを持っていますか?どんな助けでもいただければ幸いです。

4

2 に答える 2

0

非同期タスクを間違った方法で使用しました。

まず、どこでresponseBody宣言されますか?nullでないことを確認してください!!

また、他のエラーは次のとおりですresponseBody。doInBackgroundでを返します。その戻り文字列はresult、in onPostExecuteメソッドです。

したがって、.に置き換えonPostExecuteます 。responseBodyresult

  Log.i("returndata",result);

..

于 2012-08-02T20:32:55.603 に答える
0

Log.w()aまたはaprintStackTrace()をthouseの例外に入れたい場合:

   } catch (ClientProtocolException e) {
        e.printStackTrace();
   } catch (IOException e) {
        e.printStackTrace();
   }
 }
 return responseBody;
 }

を使用logcatして、それらの原因を確認できます。

この方法onPostExecuteは疑わしいようです。に置き換えresponseBodyますresult

  @Override
    protected void onPostExecute(String result) {
         Log.i("returndata",result);

    }
于 2012-08-02T21:01:37.767 に答える