0

私は Android の初心者で、php ページを接続するアプリを開発しています。ただし、コードをデバッグすると、Source not foundLast time it given it for DefaulRequestDirector.class;が表示されます。しかし、それはまたそれを与えましたAbstracthttpclient.classjsonapacheパッケージをインポートしました。

私はそれSource not foundHttpResponse httpResponse = httpClient.execute(httpPost);行で見ます。

 if(method == "POST")
            {
                // request method is POST
                // defaultHttpClient
                DefaultHttpClient httpClient = new DefaultHttpClient();
                HttpPost httpPost = new HttpPost(url);
                httpPost.setEntity(new UrlEncodedFormEntity(params));

                HttpResponse httpResponse = httpClient.execute(httpPost); // Source not found
                HttpEntity httpEntity = httpResponse.getEntity();
                is = httpEntity.getContent();

            }

LogCat:

05-15 16:15:46.133: W/dalvikvm(25727): threadid=1: thread exiting with uncaught exception (group=0x415262a0)
05-15 16:15:46.138: E/AndroidRuntime(25727): FATAL EXCEPTION: main
05-15 16:15:46.138: E/AndroidRuntime(25727): android.os.NetworkOnMainThreadException
05-15 16:15:46.138: E/AndroidRuntime(25727):    at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1118)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at java.net.InetAddress.lookupHostByName(InetAddress.java:385)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at java.net.InetAddress.getAllByName(InetAddress.java:214)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:137)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:670)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:509)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at com.example.yoritreader.JSONParser.makeHttpRequest(JSONParser.java:59)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at com.example.yoritreader.MainActivity$1.onPreviewFrame(MainActivity.java:246)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at android.hardware.Camera$EventHandler.handleMessage(Camera.java:841)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at android.os.Handler.dispatchMessage(Handler.java:99)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at android.os.Looper.loop(Looper.java:137)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at android.app.ActivityThread.main(ActivityThread.java:4921)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at java.lang.reflect.Method.invokeNative(Native Method)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at java.lang.reflect.Method.invoke(Method.java:511)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1027)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:794)
05-15 16:15:46.138: E/AndroidRuntime(25727):    at dalvik.system.NativeStart.main(Native Method)

ご協力ありがとうございました!

4

1 に答える 1

2
android.os.NetworkOnMainThreadException

を取得していNetworkOnMainThreadExceptionます。これは、UI スレッドで、ネットワークに関連する操作などのブロック操作を実行していることを意味します。この動作は常に非常に推奨されていませんが、Android 3.0 以降では禁止されています。したがって、コードを AsyncTask に移動する必要があります。

==また、Javaでは文字列の比較は演算子ではできません。

if(method == "POST")

これは間違っています。使用する必要があります

string1.equals(string2)

またstring1.equalsIgnoreCase(string2)

Thread/AsyncTask のこのガイドを読むことができます

于 2013-05-15T13:22:22.693 に答える