0

私はAndroidに非常に慣れていないため、次のような例外が発生します。

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.simplepay.hellomobile/com.simplepay.hellomobile.CardPayment}: android.os.NetworkOnMainThreadException

スタックトレースはここにあります:

at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
        at android.app.ActivityThread.access$600(ActivityThread.java:141)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:137)
        at android.app.ActivityThread.main(ActivityThread.java:5039)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:511)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
        at dalvik.system.NativeStart.main(Native Method)
        Caused by: android.os.NetworkOnMainThreadException
        at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1117)
        at libcore.io.BlockGuardOs.recvfrom(BlockGuardOs.java:163)
        at libcore.io.IoBridge.recvfrom(IoBridge.java:513)
        at java.net.PlainSocketImpl.read(PlainSocketImpl.java:488)
        at java.net.PlainSocketImpl.access$000(PlainSocketImpl.java:46)
        at java.net.PlainSocketImpl$PlainSocketInputStream.read(PlainSocketImpl.java:240)
        at org.apache.http.impl.io.AbstractSessionInputBuffer.fillBuffer(AbstractSessionInputBuffer.java:103)
        at org.apache.http.impl.io.SocketInputBuffer.isStale(SocketInputBuffer.java:109)
        at org.apache.http.impl.AbstractHttpClientConnection.isStale(AbstractHttpClientConnection.java:205)
        at org.apache.http.impl.conn.AbstractClientConnAdapter.isStale(AbstractClientConnAdapter.java:185)
        at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:336)
        at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
        at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:653)
        at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:627)
        at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:616)
        at juspay.services.WalletService.makeServiceCall(WalletService.java:283)
        at juspay.services.WalletService.getCardTokens(WalletService.java:237)
        at com.simplepay.hellomobile.CardPayment.addContentTo(CardPayment.java:107)
        at com.simplepay.hellomobile.CardPayment.setUpLayoutAndActionListeners(CardPayment.java:81)
        at com.simplepay.hellomobile.CardPayment.onCreate(CardPayment.java:56)
        at android.app.Activity.performCreate(Activity.java:5104)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)

すべてのネットワーク呼び出しは、メソッドを使用して行われAsyncTask、メソッド内に配置されていることに注意してくださいdoInBackground。コードは次のとおりです。

protected JSONObject doInBackground(Void... voids)  
{
    JSONObject initOrderResponse = walletService.initOrder(this.amount);
    return initOrderResponse;
}

whereinitOrderは通常の Java メソッドで、次のような行があります。

responseBody = httpClient.execute(post,responseHandler);

しかし、それでもこのエラーが発生します。

どこで間違いを犯しているのかわかりません。

前もって感謝します。

4

2 に答える 2

2

原因: android.os.NetworkOnMainThreadException

UI スレッドでネットワーク呼び出しを行おうとしています。

したがって、AsyncTask を使用してそのようなタスクを達成します。

Android 3.0 以降のバージョンでは、UI をブロックする可能性のあるネットワーク呼び出しまたはアクションをバックグラウンド スレッドで実行することが必須になりました。

編集:

でこれを試してくださいonCreate()

StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
StrictMode.setThreadPolicy(policy);
于 2013-02-18T07:34:51.743 に答える
1

私は人々がこのように実行しているのを見てきAsyncTaskました。new MyAsyncTask().doInBackground();の代わりにnew MyAsyncTask().execute();。意図せずにこの間違いをしていないことを確認してください。

于 2013-02-18T08:01:03.690 に答える