Exception sur httpclient.exécuter sur le serveur web
J'essaie d'envoyer des données JSON sur le serveur web et obtenir réponse par cette méthode.
public JSONObject postOnServer(JSONObject json) {
HttpResponse response;
JSONObject res = null;
HttpClient httpclient = new DefaultHttpClient();
HttpConnectionParams.setConnectionTimeout(httpclient.getParams(), 10000);
HttpPost httpPost = new HttpPost(PATH);
try {
//StringEntity stringEntity = new StringEntity("json", String.valueOf(json));
ByteArrayEntity postMessage = new ByteArrayEntity(json.toString().getBytes("UTF8"));
httpPost.setEntity(postMessage);
response = httpclient.execute(httpPost);
if (response.getStatusLine().getStatusCode() == 200) {
InputStream instream = response.getEntity().getContent();
try {
res = new JSONObject(convertStreamToString(instream));
} catch (JSONException e) {
//TODO Auto-generated catch block
Log.i("Response JSON", e.toString());
}
} else {
res = new JSONObject();
try {
res.put("error", "Unable to load page.");
} catch (JSONException e) {
//TODO Auto-generated catch block
}
}
} catch (IOException ex) {
Log.i("Connection.postOnServer", "1.try exception: "+ex);
res = new JSONObject();
try {
res.put("error", "Synchronization is not enable: Connection has aborted.");
} catch (JSONException e) {
Log.i("Connection.postOnServer", "put exception: "+e);
}
}
return res;
}
Mais toujours il fin sur la ligne de response = httpclient.execute(httpPost);
avec cette exception
05-24 10:58:51.635: E/AndroidRuntime(4709): FATAL EXCEPTION: main
05-24 10:58:51.635: E/AndroidRuntime(4709): android.os.NetworkOnMainThreadException
05-24 10:58:51.635: E/AndroidRuntime(4709): at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1099)
05-24 10:58:51.635: E/AndroidRuntime(4709): at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84)
05-24 10:58:51.635: E/AndroidRuntime(4709): at libcore.io.IoBridge.connectErrno(IoBridge.java:138)
05-24 10:58:51.635: E/AndroidRuntime(4709): at libcore.io.IoBridge.connect(IoBridge.java:112)
05-24 10:58:51.635: E/AndroidRuntime(4709): at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
05-24 10:58:51.635: E/AndroidRuntime(4709): at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
05-24 10:58:51.635: E/AndroidRuntime(4709): at java.net.Socket.connect(Socket.java:842)
05-24 10:58:51.635: E/AndroidRuntime(4709): at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119)
05-24 10:58:51.635: E/AndroidRuntime(4709): at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:144)
05-24 10:58:51.635: E/AndroidRuntime(4709): at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
05-24 10:58:51.635: E/AndroidRuntime(4709): at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
05-24 10:58:51.635: E/AndroidRuntime(4709): at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
05-24 10:58:51.635: E/AndroidRuntime(4709): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
05-24 10:58:51.635: E/AndroidRuntime(4709): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
05-24 10:58:51.635: E/AndroidRuntime(4709): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
Avoir quelqu'un d'idée, comment la réparer? Sur la soif essayer si j'utilise catch(IOException), aplication est destroyd. Si j'utilise catch(Exception) aplication, allez sur aucune action. Que dois-je faire pour envoyer des données?
- stackoverflow.com/a/4822122/1251715 même problème
- double possible de HonyComb et DefaultHttpClient
Vous devez vous connecter pour publier un commentaire.
Android ne permet pas d'exécuter les demandes de réseau sur le thread d'interface utilisateur. C'est pour arrêter les demandes de brouillage de l'interface, tandis que de leur exécution. Vous avez besoin pour l'exécution de la demande dans un thread séparé. Voici un exemple: