0

AsyncTask を介して Web サービスからデータを取得しようとしましたが、空の応答が返され、接続に時間がかかります。ここに多くのコードを入れたくはありませんでしたが、私が何をしたかを説明するより良い方法だと思います. これは、接続するために実装したクラスです。

public class WebService extends AsyncTask<String, String, String> {
    private ArrayList<SimpleObserver> listeners;
    private int responseCode;
    private String message;
    private String response;

    public WebService() {
        listeners = new ArrayList<SimpleObserver>();
    }

    public void addListener(SimpleObserver obs) {
        listeners.add(obs);
    }

    public void removeListener(SimpleObserver obs) {
        listeners.remove(obs);
    }

    public void notifyListener(String s) {
        for (SimpleObserver listener : listeners)
            listener.onChange(s);
    }

    public String getResponse() {
        return response;
    }

    public String getErrorMessage() {
        return message;
    }

    public int getResponseCode() {
        return responseCode;
    }

    @Override
    protected void onPreExecute() {
        notifyListener("Calculating..");
    }

    @Override
    protected String doInBackground(String... urls) {
        String response = "";
        for (String url : urls) {
            DefaultHttpClient client = new DefaultHttpClient();
            HttpGet httpGet = new HttpGet(url);
            try {
                notifyListener("Execute");
                HttpResponse execute = client.execute(httpGet);
                InputStream content = execute.getEntity().getContent();
                notifyListener("Chegou aqui");

                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) {
        notifyListener(result);
    }
}

そして、私が使用した電話:

public class ServiceController implements SimpleObserver {
    private Activity act;
    private WebService s;
    private static final String URL = "my url with parameters";

    public ServiceController(MainActivity mainActivity) {
        act = mainActivity;
        s = new WebService();
        s.addListener(this);
    }

    public void onChange(String s) {
        ((MainActivity) act).getTextView().setText(s);
    }

    public void executeService() {
        try {
            s.execute(new String[] { URL });
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            System.out.println(e.getMessage());
        }
    }
}

この HttpHostConnectException:Connection to 192.168.56.1:8080 が拒否されたアプリをテストしていました。ロキャットは私にこのメッセージを与えます:

08-24 16:58:02.060: W/System.err(17595): org.apache.http.conn.HttpHostConnectException: Connection to http://192.168.56.1:8080 refused
08-24 16:58:02.075: W/System.err(17595):    at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:183)
08-24 16:58:02.075: W/System.err(17595):    at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
08-24 16:58:02.075: W/System.err(17595):    at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
08-24 16:58:02.075: W/System.err(17595):    at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
08-24 16:58:02.075: W/System.err(17595):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
08-24 16:58:02.075: W/System.err(17595):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
08-24 16:58:02.075: W/System.err(17595):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
08-24 16:58:02.075: W/System.err(17595):    at com.example.pulldata.DS.WebService.doInBackground(WebService.java:68)
08-24 16:58:02.075: W/System.err(17595):    at com.example.pulldata.DS.WebService.doInBackground(WebService.java:1)
08-24 16:58:02.080: W/System.err(17595):    at android.os.AsyncTask$2.call(AsyncTask.java:264)
08-24 16:58:02.080: W/System.err(17595):    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
08-24 16:58:02.080: W/System.err(17595):    at java.util.concurrent.FutureTask.run(FutureTask.java:137)
08-24 16:58:02.080: W/System.err(17595):    at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:208)
08-24 16:58:02.080: W/System.err(17595):    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
08-24 16:58:02.080: W/System.err(17595):    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
08-24 16:58:02.085: W/System.err(17595):    at java.lang.Thread.run(Thread.java:856)
08-24 16:58:02.085: W/System.err(17595): Caused by: java.net.ConnectException: failed to connect to /192.168.56.1 (port 8080): connect failed: ETIMEDOUT (Connection timed out)
08-24 16:58:02.085: W/System.err(17595):    at libcore.io.IoBridge.connect(IoBridge.java:114)
08-24 16:58:02.085: W/System.err(17595):    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
08-24 16:58:02.085: W/System.err(17595):    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
08-24 16:58:02.085: W/System.err(17595):    at java.net.Socket.connect(Socket.java:842)
08-24 16:58:02.085: W/System.err(17595):    at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119)
08-24 16:58:02.085: W/System.err(17595):    at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:144)
08-24 16:58:02.090: W/System.err(17595):    ... 15 more
08-24 16:58:02.090: W/System.err(17595): Caused by: libcore.io.ErrnoException: connect failed: ETIMEDOUT (Connection timed out)
08-24 16:58:02.090: W/System.err(17595):    at libcore.io.Posix.connect(Native Method)
08-24 16:58:02.090: W/System.err(17595):    at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:85)
08-24 16:58:02.090: W/System.err(17595):    at libcore.io.IoBridge.connectErrno(IoBridge.java:127)
08-24 16:58:02.090: W/System.err(17595):    at libcore.io.IoBridge.connect(IoBridge.java:112)
08-24 16:58:02.095: W/System.err(17595):    ... 20 more

この問題について他の質問を検索しましたが、インターネットの許可がないためだと彼らは言っていますが、マニフェストにそれがあります! 全然わからない!

私はアンドロイドにかなり慣れていないので、助けてもらえますか?

4

2 に答える 2

0

アプリが適切なリクエストを行っていると確信していますか? HTTPResponseメソッドgetStatusLine()とで返されるステータス コードを確認する必要がありますgetStatusCode()。リクエストが正しければ、 から 200 が返されるはずですgetStatusCode()(これは ですHttpStatus.SC_OK)。それ以外の場合は、アプリが行っているリクエストがどのように見えるかを確認してください。

netcat などのツールを使用して GET メソッドでアプリが送信しているものを正確に確認して、PC のポートをリッスンし、アプリをそれに接続させることができます。

リクエストに問題がないように見える場合は、自分で手動で送信してみてください (これには netcat を使用するか、Firefox 用の優れた RESTClient デバッガー プラグインがあります)。

データが返されていることが示されている場合は、バッファリングされたリーダーに問題があると思われます。ステートメントを使用Log.d()して、コードのさまざまなポイントで文字列値を示す logcat ステートメントを出力し、進行状況を確認できます。

于 2012-08-24T15:42:20.557 に答える