50 votes

Android - android.os.NetworkOnMainThreadException

J'ai cette exception, et je lisais un thread sur ce sujet, et il semblait confus:

android.os.NetworkOnMainThreadException

J'ai déjà ajouté cette ligne dans mon manifeste:

<uses-permission android:name="android.permission.INTERNET" />

Sur cette discussion, ils parlent de la principale thread d'exécution de l'application n'étant pas en mesure de faire du réseautage. Ce que je me demande c'est comment restructurer mon code afin qu'il soit en ligne avec Android de bonnes pratiques.

Voici ma classe d'Activité pour ceci:

package com.problemio;

import java.io.InputStream;
import java.util.ArrayList;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.message.BasicNameValuePair;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
public class LoginActivity extends Activity 
{
    public void onCreate(Bundle savedInstanceState) 
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.login);

        // Show form for login_email
        final EditText loginEmail = (EditText) findViewById(R.id.login_email);  
        String name = loginEmail.getText().toString();  

        // Show field for password  
        final EditText password = (EditText) findViewById(R.id.password);  
        String text = password.getText().toString();                  

        // Show button for submit
        Button submit = (Button)findViewById(R.id.submit);   




        // Show options for create-profile and forgot-password




        submit.setOnClickListener(new Button.OnClickListener() 
        {  
           public void onClick(View v) 
           {
              String email = loginEmail.getText().toString();
              String pass = password.getText().toString(); 
              sendFeedback(pass, email);
            }
        });        
    }


    public void sendFeedback(String pass , String email) 
    {  
        Log.d( "1" , pass );
        Log.d( "1" , email );

        // Go to db and check if these r legit
        // How do I do that? :)
        ArrayList<NameValuePair> postParameters = new ArrayList<NameValuePair>();  
        postParameters.add(new BasicNameValuePair("username", email ));  
        postParameters.add(new BasicNameValuePair("password", pass ));

        String responseString = null;

        try 
        {  
            HttpClient httpclient = new DefaultHttpClient();
            HttpPost httppost = new HttpPost("myUrl");

            // no idea what this does :)
            httppost.setEntity(new UrlEncodedFormEntity(postParameters));

            // This is the line that send the request
            HttpResponse response = httpclient.execute(httppost);

            HttpEntity entity = response.getEntity();            

            InputStream is = entity.getContent();
        } 
        catch (Exception e) 
        {     
            Log.e("log_tag", "Error in http connection "+e.toString());
        }        
    }          
}

Ce que je fais mal ici, et comment pourrais-je résoudre ce problème? :) Merci!!

14voto

AnDx Points 506
if (android.os.Build.VERSION.SDK_INT > 9) {
    StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
    StrictMode.setThreadPolicy(policy);
}

     />

8voto

blackbelt Points 45840
  try 
    {  
        HttpClient httpclient = new DefaultHttpClient();
        HttpPost httppost = new HttpPost("myUrl");

        // no idea what this does :)
        httppost.setEntity(new UrlEncodedFormEntity(postParameters));

        // This is the line that send the request
        HttpResponse response = httpclient.execute(httppost);

        HttpEntity entity = response.getEntity();            

        InputStream is = entity.getContent();
    } 
    catch (Exception e) 
    {     
        Log.e("log_tag", "Error in http connection "+e.toString());
    }        
 

Voici votre problème. Depuis api 11, cette exception vous informera que vous exécutez de longues tâches sur le thread d'interface utilisateur (la communication http de votre classe) et, conformément à la nouvelle stratégie StrictGuard, cela n'est pas possible. Donc, vous avez deux choix différents

  1. Utilisez thread ou aynctask pour exécuter votre tâche à long terme (meilleur moyen)

3voto

sankar Points 900

Vous avez fait un appel réseau sur le thread principal, ce qui est contraire aux règles Android. Vous devez donc effectuer votre appel réseau sur un thread séparé, comme un asyncte ou un gestionnaire, etc.

3voto

kirti avaiya Points 991

Vous pouvez simplement créer une classe async comme ci-dessous

 class Retrievedata extends AsyncTask<String, Void, String> {
@Override
    protected String doInBackground(String... params) {
         try{
                //Your code 
                }
        return null;
    }
}
 

Vous pouvez simplement mettre votre code tout entier dans la méthode doInBackground

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X