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.