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をキャッチしています。
ありがとう、クリス
これを試して:
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();
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
次のシステムプロパティを変更することにより、jvmから作成されたすべての接続のタイムアウトを設定できます。
System.setProperty("Sun.net.client.defaultConnectTimeout", "10000");
System.setProperty("Sun.net.client.defaultReadTimeout", "10000");
すべての接続は10秒後にタイムアウトします。
'defaultReadTimeout'を設定する必要はありませんが、読み取りを制御する必要がある場合の例として示しています。
スレッドのスリープにより、手動で強制的に切断できます。これは一例です:
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");
}
}
サーバーからログをダウンロードするために同様のコードを使用しました。コードをデバッグすると、返される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リクエストを使用することでした。
Windowsを使用していますか? Windowsの基礎となるソケット実装は、SO_TIMEOUTオプションをあまりサポートしていないようです。この回答も参照してください: クライアントソケットのsetSoTimeoutはソケットに影響しません