2013-08-12 87 views
2

我在我的應用程序中發生此異常的網絡進程,我不知道如何解決此問題。在其全球IP地址我使用從我們的服務器HttpHostConnectException連接拒絕ConnectException ErrnoException

<uses-permission android:name="android.permission.INTERNET" /> 
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> 
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> 
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" /> 
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> 
<uses-permission android:name="android.permission.RECORD_AUDIO" /> 
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> 

和URI已經是:我已經在我的清單應用某些權限,這裏是我申請我的整個應用程序的權限。它在瀏覽器中正常工作,但在應用程序中,此異常出現。這裏是堆棧跟蹤:

 08-12 06:15:36.234: W/System.err(862): org.apache.http.conn.HttpHostConnectException: Connection to http://xxx.xx.xxx.xxx:8080 refused 
    08-12 06:15:36.324: W/System.err(862): at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:183) 
    08-12 06:15:36.494: W/System.err(862): at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164) 
    08-12 06:15:36.594: W/System.err(862): at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119) 
    08-12 06:15:36.785: W/System.err(862): at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360) 
    08-12 06:15:36.904: W/System.err(862): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555) 
    08-12 06:15:37.014: W/System.err(862): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487) 
    08-12 06:15:37.164: W/System.err(862): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465) 
    08-12 06:15:37.194: W/System.err(862): at com.android.app.util.Utility.getRequest(Utility.java:42) 
    08-12 06:15:37.284: W/System.err(862): at com.android.app.LoginActivity$LoginTask.doInBackground(LoginActivity.java:440) 
    08-12 06:15:37.404: W/System.err(862): at com.android.app.LoginActivity$LoginTask.doInBackground(LoginActivity.java:1) 
    08-12 06:15:37.534: W/System.err(862): at android.os.AsyncTask$2.call(AsyncTask.java:287) 
    08-12 06:15:37.744: W/System.err(862): at java.util.concurrent.FutureTask.run(FutureTask.java:234) 
    08-12 06:15:37.804: W/System.err(862): at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230) 
    08-12 06:15:37.944: W/System.err(862): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080) 
    08-12 06:15:38.044: W/System.err(862): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573) 
    08-12 06:15:38.164: W/System.err(862): at java.lang.Thread.run(Thread.java:856) 
    08-12 06:15:38.364: W/System.err(862): Caused by: java.net.ConnectException: failed to connect to /xxx.xx.xxx.xxx (port 8080): connect failed: ETIMEDOUT (Connection timed out) 
    08-12 06:15:38.394: W/System.err(862): at libcore.io.IoBridge.connect(IoBridge.java:114) 
    08-12 06:15:38.664: W/System.err(862): at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192) 
    08-12 06:15:38.845: W/System.err(862): at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459) 
    08-12 06:15:38.894: W/System.err(862): at java.net.Socket.connect(Socket.java:842) 
    08-12 06:15:39.085: W/System.err(862): at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119) 
    08-12 06:15:39.154: W/System.err(862): at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:144) 
    08-12 06:15:39.184: W/System.err(862): ... 15 more 
    08-12 06:15:39.244: W/System.err(862): Caused by: libcore.io.ErrnoException: connect failed: ETIMEDOUT (Connection timed out) 
    08-12 06:15:39.464: W/System.err(862): at libcore.io.Posix.connect(Native Method) 
    08-12 06:15:39.774: W/System.err(862): at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:85) 
    08-12 06:15:39.804: W/System.err(862): at libcore.io.IoBridge.connectErrno(IoBridge.java:127) 
    08-12 06:15:39.894: W/System.err(862): at libcore.io.IoBridge.connect(IoBridge.java:112) 
    08-12 06:15:39.984: W/System.err(862): ... 20 more 

任何幫助將不勝感激。謝謝。

編輯: 好了,這裏是我的工具:

public static String getRequest(String path){ 
    String url = http://xxx.xx.xxx.xxx:8080/SampleApi/sample-apis; // Global URL of the API 
    String username = "sampleuname"; 
    String password = "samplepass"; 

    CredentialsProvider credProvider = new BasicCredentialsProvider(); 
    credProvider.setCredentials(new AuthScope(AuthScope.ANY_HOST, AuthScope.ANY_PORT), 
      new UsernamePasswordCredentials(username, password)); 

    try{ 
     DefaultHttpClient httpClient = new DefaultHttpClient(); 
     httpClient.setCredentialsProvider(credProvider); 
     HttpGet httpGet = new HttpGet(url + path); 
     HttpResponse httpResponse = httpClient.execute(httpGet); // Okay, so the stack trace is pointing in this line 

     HttpEntity httpEntity = httpResponse.getEntity(); 
     if(httpEntity != null){ 
      inStream = httpEntity.getContent(); 
      String jsonString = convertStreamToString(inStream); 
      return jsonString; 
     } 
    } catch (UnsupportedEncodingException e) { 
     e.printStackTrace(); 
    } catch (ClientProtocolException e) { 
     e.printStackTrace(); 
    } catch (IOException e) { 
     e.printStackTrace(); 
    } 

    return "Request NULL"; 
} 

和我通話的AsyncTask:

public class LoginTask extends AsyncTask<String, Void, String> { 

    @Override 
    protected String doInBackground(String... path) { 
     Log.d(Constant.TAG_LOGIN, path[0]); 

     String apiRequestReturn = Utility.getRequest(path[0]); // So here's the other line pointed by the stack trace where I called Utility 
     if (apiRequestReturn.equals("")) { 
      Log.d(Constant.TAG_LOGIN, "WebService request is null"); 
      return null; 
     } else { 
      Log.d(Constant.TAG_LOGIN, "WebService request has data"); 
      return apiRequestReturn; 
     } 
    } 

    @Override 
    protected void onPostExecute(String result) { 
     super.onPostExecute(null); 

     //JSON PARSING 
    } 
} 
+1

DefaultClientConnectionOperator.java:183:你可以發表這段代碼嗎? &AbstractHttpClient.java – KOTIOS

+0

相同的請求在瀏覽器中工作嗎? –

+0

@ Stacks28'DefaultClientConnectionOperator.java'屬於apache:'org.apache.http.impl.conn.DefaultClientConnectionOperator' @StefandeBruijn是的,它適用於瀏覽器。 –

回答

5

我LSO面對我的設備同樣的問題。具有json響應的URI在瀏覽器中正常工作,但在設備中引發異常。我只是重新啓動我的設備,然後它在移動端工作。您嘗試重新啓動您的設備。

+0

哇。有效! – Chicowitz

0

請按照這些解決方案解決您的問題。

1>檢查你的清單文件的互聯網許可有沒有。

2>通過休息客戶端瀏覽器檢查您的URL並傳遞適當的請求。

3>打開手機中的網址如: - http://yourIP地址/端口這只是爲了檢查您是否有權限或不在移動中打開此網址。