2011-12-23 2 views
8

У меня возникли проблемы с моей андроид функциональность входа, получая android.os.NetworkOnMainThreadExceptionandroid.os.NetworkOnMainThreadException. Нужно использовать асинхронную задачу?

Я удалил поле пароля только сейчас, чтобы проверить, если только имя пользователя было быть в курсе, я знаю, что это проблема для андроид 3.2 +.

Вот мой код:

package com.example.toknapp; 

import java.util.ArrayList; 

public class login2 extends Activity { 
    EditText un; 
    TextView error; 
    Button ok; 
    /** Called when the activity is first created. */ 
    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.login); 
     un=(EditText)findViewById(R.id.et_un); 
     ok=(Button)findViewById(R.id.btn_login); 
     error=(TextView)findViewById(R.id.tv_error); 

     ok.setOnClickListener(new View.OnClickListener() { 

      @Override 
      public void onClick(View v) { 
       // TODO Auto-generated method stub 

       ArrayList<NameValuePair> postParameters = new ArrayList<NameValuePair>(); 
       postParameters.add(new BasicNameValuePair("username", un.getText().toString())); 
       //String valid = "1"; 
       String response = null; 
       try { 
        response = CustomHttpClient.executeHttpPost("http://tokn.me/android_merchant_login.php", postParameters); 
        String res=response.toString(); 
        // res = res.trim(); 
        res= res.replaceAll("\\s+","");        
        //error.setText(res); 

        if(res.equals("1")) 
         error.setText("Correct Username or Password"); 
        else 
         error.setText("Sorry!! Incorrect Username or Password"); 
       } catch (Exception e) { 
        un.setText(e.toString()); 
       } 

      } 
     }); 
    } 
} 


package com.example.toknapp; 

import java.io.BufferedReader; 
import java.io.IOException; 
import java.io.InputStreamReader; 
import java.net.URI; 
import java.util.ArrayList; 

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.HttpGet; 
import org.apache.http.client.methods.HttpPost; 
import org.apache.http.conn.params.ConnManagerParams; 
import org.apache.http.impl.client.DefaultHttpClient; 
import org.apache.http.params.HttpConnectionParams; 
import org.apache.http.params.HttpParams; 

public class CustomHttpClient { 
    /** The time it takes for our client to timeout */ 
    public static final int HTTP_TIMEOUT = 30 * 1000; // milliseconds 

    /** Single instance of our HttpClient */ 
    private static HttpClient mHttpClient; 

    /** 
    * Get our single instance of our HttpClient object. 
    * 
    * @return an HttpClient object with connection parameters set 
    */ 
    private static HttpClient getHttpClient() { 
     if (mHttpClient == null) { 
      mHttpClient = new DefaultHttpClient(); 
      final HttpParams params = mHttpClient.getParams(); 
      HttpConnectionParams.setConnectionTimeout(params, HTTP_TIMEOUT); 
      HttpConnectionParams.setSoTimeout(params, HTTP_TIMEOUT); 
      ConnManagerParams.setTimeout(params, HTTP_TIMEOUT); 
     } 
     return mHttpClient; 
    } 

    /** 
    * Performs an HTTP Post request to the specified url with the 
    * specified parameters. 
    * 
    * @param url The web address to post the request to 
    * @param postParameters The parameters to send via the request 
    * @return The result of the request 
    * @throws Exception 
    */ 
    public static String executeHttpPost(String url, ArrayList<NameValuePair> postParameters) throws Exception { 
     BufferedReader in = null; 
     try { 
      HttpClient client = getHttpClient(); 
      HttpPost request = new HttpPost(url); 
      UrlEncodedFormEntity formEntity = new UrlEncodedFormEntity(postParameters); 
      request.setEntity(formEntity); 
      HttpResponse response = client.execute(request); 
      in = new BufferedReader(new InputStreamReader(response.getEntity().getContent())); 

      StringBuffer sb = new StringBuffer(""); 
      String line = ""; 
      String NL = System.getProperty("line.separator"); 
      while ((line = in.readLine()) != null) { 
       sb.append(line + NL); 
      } 
      in.close(); 

      String result = sb.toString(); 
      return result; 
     } finally { 
      if (in != null) { 
       try { 
        in.close(); 
       } catch (IOException e) { 
        e.printStackTrace(); 
       } 
      } 
     } 
    } 

    /** 
    * Performs an HTTP GET request to the specified url. 
    * 
    * @param url The web address to post the request to 
    * @return The result of the request 
    * @throws Exception 
    */ 
    public static String executeHttpGet(String url) throws Exception { 
     BufferedReader in = null; 
     try { 
      HttpClient client = getHttpClient(); 
      HttpGet request = new HttpGet(); 
      request.setURI(new URI(url)); 
      HttpResponse response = client.execute(request); 
      in = new BufferedReader(new InputStreamReader(response.getEntity().getContent())); 

      StringBuffer sb = new StringBuffer(""); 
      String line = ""; 
      String NL = System.getProperty("line.separator"); 
      while ((line = in.readLine()) != null) { 
       sb.append(line + NL); 
      } 
      in.close(); 

      String result = sb.toString(); 
      return result; 
     } finally { 
      if (in != null) { 
       try { 
        in.close(); 
       } catch (IOException e) { 
        e.printStackTrace(); 
       } 
      } 
     } 
    } 
} 
+0

Вы ответили сами. Используйте задачу Async! – rDroid

+0

Я понятия не имею, где, я очень очень новичок в разработке Android. Единственное, что я сделал до сих пор, это сделать вкладку макета и изменить main.xml: p – re1man

ответ

10

Я предполагаю, что вы пытаетесь peform какой-то операция сети на главном потоке

NetworkOnMainThreadException из Документов

Исключения, которое возникает, когда приложение пытается выполнить сетевую операцию в своем основном потоке.

UPDATE:

Его лучше использовать AsyncTask

private class MyAsyncTask extends AsyncTask<Void, Void, Void> 
    { 

     ProgressDialog mProgressDialog; 
     @Override 
     protected void onPostExecute(Void result) { 
      mProgressDialog.dismiss(); 
     } 

     @Override 
     protected void onPreExecute() { 
      mProgressDialog = ProgressDialog.show(ActivityName.this, 
              "Loading...", "Data is Loading..."); 
     } 

     @Override 
     protected Void doInBackground(Void... params) { 
      // your network operation 
      return null; 
     } 
    } 
+0

да, указано, что я должен использовать задачу async. Просто нужно знать, как это работает:> 3.2 – re1man

+0

Обратитесь к Документам для [AsyncTask] (http://developer.android.com/reference/android/os/AsyncTask.html), это объяснило красиво –

+0

checkout [здесь] (http : //stackoverflow.com/questions/8515377/launching-a-long-running-task-from-an-alertdialog-android/8515395#8515395) как использовать AsyncTask. –

0

Пожалуйста, проверьте этот link. он описывает все, что вам нужно будет сделать.

[править]

Кажется, они изменили страницу. Это link покажет вам, как использовать асинхронные задачи

+1

не работает .... – Ahmad

+1

Может быть этот: http://android-developers.blogspot.co.uk/2009/05/painless-threading.html – DilbertDave

2

Просто измените целевую версию в файле манифеста на любовника, чем Honeycomb.

<uses-sdk 
    android:minSdkVersion="8" 
    android:targetSdkVersion="8" /> 

Редактировать: Но использование AsyncTask - более удобный способ решить эту проблему.

+0

+1 потому что он разрешает ошибку. Но лучше использовать асинхронные задачи. – pocjoc

+0

Это не решит проблему, что вы не должны блокировать приложение с помощью синхронной задачи. – utopalex

Смежные вопросы