sql >> Databáze >  >> RDS >> Mysql

Android – dotaz JSON mySQL poskytuje výjimku NetworkOnMainThreadException

Slyšel jsem, že počínaje ICS není povoleno provádět síťové operace na vláknu uživatelského rozhraní (hlavním). Proto musíte tuto operaci provést v samostatném vláknu. Buď tedy použijte AsyncTask , Vlákno nebo HandlerThread s Looper and Handler k provedení webové operace. Pokud to zkusíte na zařízení se systémem froyo nebo gingerbread, bude to v pořádku, ale ne na ICS.

Pokud jde o váš pokus o spuštění přes handler nebo AsyncTask, záleží na tom, jak jste to udělali. Vložte tento kód, abych viděl problém.

Aktualizovat

public class MySQLAndroidActivity extends ListActivity {

    private static final String url = "http://X.X.X.X/test.php";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity2);

        LoadTask t = new LoadTask();
        t.execute(null);

    }

    private static class LoadTask extends AsyncTask<Void, Void, Void> {
        @Override
        protected void onPreExecute() {

        }

        @Override
        protected Void doInBackground(Void... params) {
            doStuff();

            return null;
        }
    }





    public static void doStuff() {
        JSONArray jArray;
        String result = null;
        InputStream is = null;
        StringBuilder sb = null;
        HttpResponse response;
        HttpEntity entity;

        ArrayList<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();
        // http post
        try {
            HttpClient httpclient = new DefaultHttpClient();

            HttpPost httppost = new HttpPost(url);

            httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
            response = httpclient.execute(httppost);

            entity = response.getEntity();

            is = entity.getContent();

        } catch (Exception e) {
            Log.e("log_tag", "Error in http connection" + e.toString());
            System.exit(1);
        }

        // convert response to string
        try {
            BufferedReader reader = new BufferedReader(new InputStreamReader(is, "iso-8859-1"), 8);
            sb = new StringBuilder();
            sb.append(reader.readLine() + "\n");

            String line;
            while ((line = reader.readLine()) != null) {
                sb.append(line);
            }
            is.close();
            result = sb.toString();

            Log.i("json string", result);
        } catch (Exception e) {
            Log.e("log_tag", "Error converting result " + e.toString());
        }


        // parsing data
        String idfriend;
        String id1;
        String id2;
        try {
            jArray = new JSONArray(result);
            JSONObject json_data = null;

            System.out.println("Length " + jArray.length());
            Log.d("DB", "Length " + jArray.length());

            for (int i = 0; i < jArray.length(); i++) {

                System.out.println("counter " + i);
                json_data = jArray.getJSONObject(i);
                idfriend = json_data.getString("idfriend");
                id1 = json_data.getString("id1");
                id2 = json_data.getString("id2");

                System.out.println("id1: " + id1);
            }
        } catch (JSONException e1) {
            Log.d("DB", "Error somewhere");
        } catch (ParseException e1) {
            e1.printStackTrace();
        }
    }

}

*Došlo k problémům s voláním metod a nejdůležitější bylo, že jste klíče načítali z JSONObject jako Idfriend, Id1, Id2 což je špatně, protože ve vašem řetězci json jsou klíče jako idfriend, id1, id2 . Rozlišují se v něm velká a malá písmena, proto to havarovalo.



  1. Typ MySQL pro uložení roku:Smallint nebo Varchar nebo datum?

  2. Nahrazení kurzorů SQL alternativami, abyste se vyhnuli problémům s výkonem

  3. Jak může nastavení jazyka ovlivnit výsledky FORMAT() na serveru SQL (příklady T-SQL)

  4. Vložte pole záznamů do mysql pomocí Node JS