0

Android のログインと登録に関する優れたチュートリアルに従っています http://www.androidhive.info/2012/01/android-login-and-registration-with-php-mysql-and-sqlite/

コードを自分のプロジェクトに実装しましたが、エラーが発生し続けました。そこで、彼のコードが機能しているかどうか試してみることにしました。何が間違っているのか何時間も検索した後、私は彼のコードをコピーしてそこから行くことにしました。しかし、彼のコードを私のプロジェクトにコピーアンドペーストしただけでも、エラーが発生し続けます。

これが私のlogcatエラーです。誰かが私を正しい方向に向けることができれば、とてもうれしいです。

01-15 10:12:26.822: E/AndroidRuntime(1935): FATAL EXCEPTION: main
01-15 10:12:26.822: E/AndroidRuntime(1935): android.os.NetworkOnMainThreadException
01-15 10:12:26.822: E/AndroidRuntime(1935): at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1117)                                        
01-15 10:12:26.822: E/AndroidRuntime(1935):     at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at libcore.io.IoBridge.connectErrno(IoBridge.java:127)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at libcore.io.IoBridge.connect(IoBridge.java:112)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at java.net.Socket.connect(Socket.java:842)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:144)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at com.example.androidbasic12.library.JSONParser.getJSONFromUrl(JSONParser.java:42)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at com.example.androidbasic12.library.UserFunctions.loginUser(UserFunctions.java:38)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at com.example.androidbasic12.MainActivity$1.onClick(MainActivity.java:57)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at android.view.View.performClick(View.java:4202)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at android.view.View$PerformClick.run(View.java:17340)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at android.os.Handler.handleCallback(Handler.java:725)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at android.os.Handler.dispatchMessage(Handler.java:92)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at android.os.Looper.loop(Looper.java:137)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at android.app.ActivityThread.main(ActivityThread.java:5039)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at java.lang.reflect.Method.invokeNative(Native Method)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at java.lang.reflect.Method.invoke(Method.java:511)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
01-15 10:12:26.822: E/AndroidRuntime(1935):     at dalvik.system.NativeStart.main(Native Method)`

JSONParser.class:

public class JSONParser {

static InputStream is = null;
static JSONObject jObj = null;
static String json = "";

// constructor
public JSONParser() {

}

public JSONObject getJSONFromUrl(String url, List<NameValuePair> params) {

    // Making HTTP request
    try {
        // defaultHttpClient
        DefaultHttpClient httpClient = new DefaultHttpClient();
        HttpPost httpPost = new HttpPost(url);
        httpPost.setEntity(new UrlEncodedFormEntity(params));

        HttpResponse httpResponse = httpClient.execute(httpPost);
        HttpEntity httpEntity = httpResponse.getEntity();
        is = httpEntity.getContent();

    } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
    } catch (ClientProtocolException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }

    try {
        BufferedReader reader = new BufferedReader(new InputStreamReader(
                is, "iso-8859-1"), 8);
        StringBuilder sb = new StringBuilder();
        String line = null;
        while ((line = reader.readLine()) != null) {
            sb.append(line + "\n");
        }
        is.close();
        json = sb.toString();
        Log.e("JSON", json);
    } catch (Exception e) {
        Log.e("Buffer Error", "Error converting result " + e.toString());
    }

    // try parse the string to a JSON object
    try {
        jObj = new JSONObject(json);            
    } catch (JSONException e) {
        Log.e("JSON Parser", "Error parsing data " + e.toString());
    }

    // return JSON String
    return jObj;

}

}

4

2 に答える 2

1

メイン UI スレッドでネットワーク操作を実行しています。ターゲット SDK が 11 (Honeycomb) 以上の場合、これは をスローします。これはNetworkOnMainThreadException 、この動作が UI をブロックし、アプリが応答しなくなる可能性があるためです。

メソッドにデータをロードして、これを回避するには AsyncTask を使用する必要がありますdoInBackground(..)

于 2013-01-15T10:27:18.777 に答える
0

を取得していNetworkOnMainThreadExceptionます。これは、ネットワーク操作が UI スレッドで行われていることを意味します。これは、API 11 以降の Android では許可されていません。

ネットワーク操作をバックグラウンドスレッドに移動するか、代わりにAsyncTaskを使用します。

このチュートリアルは役立つかもしれません:

http://www.vogella.com/articles/AndroidBackgroundProcessing/article.html

于 2013-01-15T10:28:20.643 に答える