web-dev-qa-db-ja.com

Java URLConnection Timeout

HTTP URLからXMLファイルを解析しようとしています。 XMLフェッチがそれよりも長くかかる場合、15秒のタイムアウトを構成したいので、タイムアウトを報告します。何らかの理由で、setConnectTimeoutとsetReadTimeoutは機能しません。コードは次のとおりです。

          URL url = new URL("http://www.myurl.com/sample.xml");
          URLConnection urlConn = url.openConnection();
          urlConn.setConnectTimeout(15000);
          urlConn.setReadTimeout(15000);
          urlConn.setAllowUserInteraction(false);         
          urlConn.setDoOutput(true);

          InputStream inStream = urlConn.getInputStream();
          InputSource input = new InputSource(inStream);

そして、私はSocketTimeoutExceptionをキャッチしています。

ありがとう、クリス

52
Chris

これを試して:

       import Java.net.HttpURLConnection;

       URL url = new URL("http://www.myurl.com/sample.xml");

       HttpURLConnection huc = (HttpURLConnection) url.openConnection();
       HttpURLConnection.setFollowRedirects(false);
       huc.setConnectTimeout(15 * 1000);
       huc.setRequestMethod("GET");
       huc.setRequestProperty("User-Agent", "Mozilla/5.0 (Windows; U; Windows NT 6.0; en-US; rv:1.9.1.2) Gecko/20090729 Firefox/3.5.2 (.NET CLR 3.5.30729)");
       huc.connect();
       InputStream input = huc.getInputStream();

OR

       import org.jsoup.nodes.Document;

       Document doc = null;
       try {
           doc = Jsoup.connect("http://www.myurl.com/sample.xml").get();
       } catch (Exception e) {
           //log error
       }

そして、Jsoupの使用方法を見てみましょう: http://jsoup.org/cookbook/input/load-document-from-url

27
Mat B.

次のシステムプロパティを変更することにより、jvmから作成されたすべての接続のタイムアウトを設定できます。

System.setProperty("Sun.net.client.defaultConnectTimeout", "10000");
System.setProperty("Sun.net.client.defaultReadTimeout", "10000");

すべての接続は10秒後にタイムアウトします。

'defaultReadTimeout'を設定する必要はありませんが、読み取りを制御する必要がある場合の例として示しています。

9
Arjen Rodenhuis

スレッドのスリープにより、手動で強制的に切断できます。これは一例です:

URLConnection con = url.openConnection();
con.setConnectTimeout(5000);
con.setReadTimeout(5000);
new Thread(new InterruptThread(con)).start();

それから

public class InterruptThread implements Runnable {

    HttpURLConnection con;
    public InterruptThread(HttpURLConnection con) {
        this.con = con;
    }

    public void run() {
        try {
            Thread.sleep(5000); // or Thread.sleep(con.getConnectTimeout())
        } catch (InterruptedException e) {

        }
        con.disconnect();
        System.out.println("Timer thread forcing to quit connection");
    }
}
9
kinghomer

サーバーからログをダウンロードするために同様のコードを使用しました。コードをデバッグすると、返されるURLConnectionの実装がSun.net.www.protocol.http.HttpURLConnectionであることがわかりました。

抽象クラスJava.net.URLConnectionには、connectTimeoutとreadTimeoutの2つの属性があり、setterは抽象クラスにあります。実装を信じているかどうかにかかわらず、Sun.net.www.protocol.http.HttpURLConnectionは同じ属性を持っていますしたがって、connectTimeoutとreadTimeoutはgetInputStreamメソッドで使用されることはないため、設定の使用はありません。私の意見では、これはSun.net.www.protocol.http.HttpURLConnection実装のバグです。

これに対する私のソリューションは、HttpClientとGetリクエストを使用することでした。

7
dino.keco

Windowsを使用していますか? Windowsの基礎となるソケット実装は、SO_TIMEOUTオプションをあまりサポートしていないようです。この回答も参照してください: クライアントソケットのsetSoTimeoutはソケットに影響しません

0
xpmatteo