-1

私は Eclipse でアプリケーションを開発し、Android 2.1 API 7 を使用し、アプリケーションは外部データベース (JSON) と対話します。エミュレーターが Android 2.1 の場合は問題ありませんが、エミュレーターを Android 4.0 の場合、外部データベースとやり取りするとアプリケーションがクラッシュします...

Logcat ログ :

11-18 18:44:56.852: D/dalvikvm(601): Not late-enabling CheckJNI (already on)
11-18 18:44:58.141: D/gralloc_goldfish(601): Emulator without GPU emulation detected.
11-18 18:44:58.301: W/TextLayoutCache(601): computeValuesWithHarfbuzz -- need to force to single run
11-18 18:44:58.301: W/TextLayoutCache(601): computeValuesWithHarfbuzz -- need to force to single run
11-18 18:45:06.601: D/AndroidRuntime(601): Shutting down VM
11-18 18:45:06.601: W/dalvikvm(601): threadid=1: thread exiting with uncaught exception (group=0x409961f8)
11-18 18:45:06.631: E/AndroidRuntime(601): FATAL EXCEPTION: main
11-18 18:45:06.631: E/AndroidRuntime(601): android.os.NetworkOnMainThreadException
11-18 18:45:06.631: E/AndroidRuntime(601):  at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1084)
11-18 18:45:06.631: E/AndroidRuntime(601):  at java.net.InetAddress.lookupHostByName(InetAddress.java:391)
11-18 18:45:06.631: E/AndroidRuntime(601):  at java.net.InetAddress.getAllByNameImpl(InetAddress.java:242)
11-18 18:45:06.631: E/AndroidRuntime(601):  at java.net.InetAddress.getAllByName(InetAddress.java:220)
11-18 18:45:06.631: E/AndroidRuntime(601):  at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:137)
11-18 18:45:06.631: E/AndroidRuntime(601):  at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
11-18 18:45:06.631: E/AndroidRuntime(601):  at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
11-18 18:45:06.631: E/AndroidRuntime(601):  at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
11-18 18:45:06.631: E/AndroidRuntime(601):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
11-18 18:45:06.631: E/AndroidRuntime(601):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
11-18 18:45:06.631: E/AndroidRuntime(601):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
11-18 18:45:06.631: E/AndroidRuntime(601):  at com.example.library.JSONParser.getJSONFromUrl(JSONParser.java:42)
11-18 18:45:06.631: E/AndroidRuntime(601):  at com.example.library.UserFunctions.loginUser(UserFunctions.java:32)
11-18 18:45:06.631: E/AndroidRuntime(601):  at com.example.lagrandechasse.LoginActivity$1.onClick(LoginActivity.java:54)
11-18 18:45:06.631: E/AndroidRuntime(601):  at android.view.View.performClick(View.java:3480)
11-18 18:45:06.631: E/AndroidRuntime(601):  at android.view.View$PerformClick.run(View.java:13983)
11-18 18:45:06.631: E/AndroidRuntime(601):  at android.os.Handler.handleCallback(Handler.java:605)
11-18 18:45:06.631: E/AndroidRuntime(601):  at android.os.Handler.dispatchMessage(Handler.java:92)
11-18 18:45:06.631: E/AndroidRuntime(601):  at android.os.Looper.loop(Looper.java:137)
11-18 18:45:06.631: E/AndroidRuntime(601):  at android.app.ActivityThread.main(ActivityThread.java:4340)
11-18 18:45:06.631: E/AndroidRuntime(601):  at java.lang.reflect.Method.invokeNative(Native Method)
11-18 18:45:06.631: E/AndroidRuntime(601):  at java.lang.reflect.Method.invoke(Method.java:511)
11-18 18:45:06.631: E/AndroidRuntime(601):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
11-18 18:45:06.631: E/AndroidRuntime(601):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
11-18 18:45:06.631: E/AndroidRuntime(601):  at dalvik.system.NativeStart.main(Native Method)
11-18 18:45:08.711: I/Process(601): Sending signal. PID: 601 SIG: 9

手伝って頂けますか ?

ご回答ありがとうございます。これは私のログイン クラスです。

public class LoginActivity extends Activity {

    //My variable

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.login);

        //initialize button and textwiew

        btnLogin.setOnClickListener(new View.OnClickListener() {

            public void onClick(View view) {

                UserFunctions userFunction = new UserFunctions();
                JSONObject json = userFunction.loginUser(login,pass);

                try {
                    if (json.getString(success) != null) {
                        loginErrorMsg.setText("");
                        String res = json.getString(success);
                        if(Integer.parseInt(res) == 1){

                            DatabaseHandler db = new DatabaseHandler(getApplicationContext());
                            JSONObject json_user = json.getJSONObject("user");

                            userFunction.logoutUser(getApplicationContext());
                            db.addUser(json_user.getString(ID), json_user.getString(login));                        

                            Intent dashboard = new Intent(getApplicationContext(), DashboardActivity.class);

                            dashboard.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
                            startActivity(dashboard);

                            finish();
                        }
                        else{
                            loginErrorMsg.setText("Error");
                        }
                    }
                } catch (JSONException e) {
                    e.printStackTrace();
                }
            }
        });
    }
}

修正を見せてもらえますか?ありがとう !

4

3 に答える 3

0

メインスレッドでネットワーク操作を行うことはできません。これは、ログトレースが示していることです。

11-18 18:45:06.631: E/AndroidRuntime(601): FATAL EXCEPTION: main 11-18 18:45:06.631: E/AndroidRuntime(601): android.os.NetworkOnMainThreadException

常に別のスレッドでネットワーキングを行ってください。を使用するasyncTaskか、自分で新しいスレッドを開始するなど、さまざまな方法でこれを実現できます。SOにはこれに関する投稿がたくさんあり、Webには多くの例があります。このSO投稿を見てください

于 2012-11-18T19:10:25.683 に答える
0

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

AsyncTaskにデータをロードすることで、これを回避するために を使用できますdoInBackground(..)

于 2012-11-18T18:55:04.343 に答える
0

このように使用..

public class getConnection extends AsyncTask<String, Void, Void> 
    {


           @Override
            protected void onPreExecute() 
           {
               super.onPreExecute();

           }

           @Override
           protected Void doInBackground(String... arg0)
           {

            try 
            {
                 //Your JSON Code  
            } 
            catch (Exception e) 
            {
             e.printStackTrace();
            }

            return null;
           }

           @Override
           protected void onPostExecute(Void result)
           {
               super.onPostExecute(result);


            }
            catch (Exception e)
            {
             Log.v("log", e.toString());
            }
           }

          }
于 2012-11-18T19:00:33.497 に答える