2

アプリケーションにこの例外が発生するネットワーク プロセスがあり、これを修正する方法がわかりません。マニフェストに特定のアクセス許可を既に適用しました。アプリ全体に適用したアクセス許可は次のとおりです。

<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 は、サーバーのグローバル IP アドレスにあるものです。ブラウザでは正常に動作しますが、アプリではこの例外が発生します。スタック トレースは次のとおりです。

        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
    }
}
4

2 に答える 2

5

私も自分のデバイスで同じ問題に直面しました。json 応答を含む URI はブラウザーでは正常に機能しますが、デバイスでは例外がスローされます。デバイスを再起動しただけで、モバイル側で動作しています。デバイスを再起動しようとしました。

于 2013-12-15T10:31:04.970 に答える
0

これらの解決策に従ってください。これらの解決策が問題を解決する可能性があります。

1>マニフェストファイルのインターネット許可がそこにあるかどうかを確認してください。

2>残りのクライアントでブラウザでURLを確認し、適切なリクエストを渡します。

3> 次のようにモバイルでURL を開きます

于 2015-02-10T09:42:42.373 に答える