2012-10-27 28 views
5

Próbuję zaimplementować klasę httpClient, która jest AsyncTask (w przeciwnym razie otrzymuję wyjątek ze względu na połączenie w głównym wątku). Próbowałem coś takiego:Android Async Http Uzyskaj żądanie

private class execHttpAsync extends AsyncTask <String, String, HttpResponse> 
    { 
     public String resultString; 

     @Override 
     protected HttpResponse doInBackground(String... params) 
     { 
      String url = params[0]; 

      HttpClient httpClient = new DefaultHttpClient(); 
      HttpGet request = new HttpGet(url);   
      request.setHeader("Content-Type", "text/xml"); 
      HttpResponse response; 
      try { 
       response = httpClient.execute(request); 
      } catch (ClientProtocolException e) { 
       // TODO Auto-generated catch block 
       e.printStackTrace(); 
      } catch (IOException e) { 
       // TODO Auto-generated catch block 
       e.printStackTrace(); 
      } 
      return response; 
     } 

     @Override 
     protected void onPostExecute(HttpResponse result) 
     { 
      StringBuffer returned = new StringBuffer(); 

      InputStream content = result.getEntity().getContent(); 
      BufferedReader rd = new BufferedReader(new InputStreamReader(content, "UTF-8"));     
      String line; 
      while ((line = rd.readLine()) != null) 
      { 
       String endOfLine = ""; 
       returned.append(line + endOfLine); 
      } 
      content.close(); 

     String retVal = returned.toString(); 

     try 
     { 
      String header = retVal.substring(0, 1); 
      if (!header.equals("<")) 
       { 
       retVal = retVal.replace(header, ""); 
       } 
     } 
     catch (Exception e) 
     { 
      // TODO: handle exception 
     } 

     resultString = returned.toString(); 

     } 

    } 

Ale muszę dostać odpowiedź w końcu. Próbowałem utworzyć instancję tej klasy, a następnie uzyskać odpowiedź jako członek, ale to się nie udało. Jakieś sugestie?

+0

Jakiego rodzaju błędu doświadczasz? Nie otrzymujesz wyniku? Opublikuj stos, jeśli istnieje. –

Odpowiedz

12

wypróbować ten sposób

private class DownloadWebPageTask extends AsyncTask<String, Void, String> { 
    @Override 
    protected String doInBackground(String... urls) { 
     String response = ""; 
     for (String url : urls) { 
     DefaultHttpClient client = new DefaultHttpClient(); 
     HttpGet httpGet = new HttpGet(url); 
     try { 
      HttpResponse execute = client.execute(httpGet); 
      InputStream content = execute.getEntity().getContent(); 

      BufferedReader buffer = new BufferedReader(new InputStreamReader(content)); 
      String s = ""; 
      while ((s = buffer.readLine()) != null) { 
      response += s; 
      } 

     } catch (Exception e) { 
      e.printStackTrace(); 
     } 
     } 
     return response; 
    } 

    @Override 
    protected void onPostExecute(String result) { 
     textView.setText(result); 
    } 
    } 
1

Jest to operacja asynchroniczna, więc coś takiego:

myRetValue = new myAsyncTask.execute(); 

NIE przypisze wartości zwracanej z onPostExecute() do myRetValue. Twój

resultString = returned.toString(); 

powinno skutkować posiadaniem cokolwiek returned.toString() produkowane przypisany resultString zmiennej (co chyba jest zadeklarowana poza klasą AsyncTask, więc w zasadzie kod wygląda dobrze na pierwszy rzut oka. Może po prostu nie mają nic returned. Spróbuj sadzę kilka punktów przerwania w kodzie AsyncTask i sprawdzam, czy naprawdę zachowuje się tak jak myślisz.