Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

Android - JSON mySQL क्वेरी NetworkOnMainThreadException देता है

मैंने सुना है कि आईसीएस से शुरू होकर, इसे यूआई (मुख्य) थ्रेड पर नेटवर्क संचालन करने की अनुमति नहीं है। इसलिए, आपको इस ऑपरेशन को एक अलग थ्रेड में करने की आवश्यकता है। तो या तो AsyncTask . का उपयोग करें , थ्रेड या HandlerThread लूपर और हैंडलर के साथ वेब संचालन करने के लिए। अगर आप इसे फ्रोयो या जिंजरब्रेड चलाने वाले डिवाइस पर आजमाते हैं, तो यह ठीक रहेगा लेकिन आईसीएस पर नहीं।

हैंडलर या AsyncTask के माध्यम से इसे चलाने के आपके प्रयास के संबंध में, यह इस बात पर निर्भर करता है कि आपने इसे कैसे किया। उस कोड को पेस्ट करें ताकि मुझे समस्या दिखाई दे।

अपडेट करें

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();
        }
    }

}

*कुछ विधि कॉलिंग समस्याएं थीं और सबसे महत्वपूर्ण यह था कि आप JSONObject से Idfriend, Id1, Id2 के रूप में कुंजी निकाल रहे थे। जो गलत है क्योंकि आपके जेसन स्ट्रिंग में चाबियाँ idfriend, id1, id2 . जैसी हैं . इसका केस-संवेदी, इसलिए यह क्रैश हो रहा था।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. लोड हो रहा है क्लास `com.mysql.jdbc.Driver'। यह बहिष्कृत है। नया ड्राइवर वर्ग `com.mysql.cj.jdbc.Driver' है

  2. MySQL - कस्टम सॉर्ट के लिए उपयोगकर्ता द्वारा परिभाषित फ़ंक्शन बनाना

  3. इस SQL ​​​​में t क्या संदर्भित करता है?

  4. mysql तालिका में टेक्स्ट कैसे खोजें और बदलें?

  5. ASP.NET MVC से mySQL के लिए सर्वश्रेष्ठ ORM विकल्प