2013-05-14 4 views
5

JavaFXアプリケーションをブラウザから(Web Startとして)実行しているときに、私は奇妙なJSoup問題を抱えています。JSoupがランダムにjava.io.IOExceptionをスローする:ブラウザから実行するとストリームが閉じられる

IDE(EclipseまたはNetbeans)の内部またはスタンドアロンアプリとして実行すると、正常に実行されます。 Web Startやブラウザ(Chrome)から実行しようとすると、JSoupは「java.io.IOException:ストリームが閉じている」ということをランダムにスローします。

私が解析しようとしているサイトはthepiratebay.sxです。私が最初に(ブラウザから)アプリケーションを実行すると、私はこのエラーが発生します。アプリケーションの実行中に、私が再び解析しようとすると、動作するよりも...時には。

JSoupコード:

try { 
    //TODO: Change to HttpFetcher. This method is reporting "stream is closed" when running on browser 
    Connection con = Jsoup.connect(url) 
      .timeout(HTTP_TIMEOUT) 
      .userAgent(UserAgentGenerator.getUserAgent()) 
      .followRedirects(false); 
    doc = con.get(); 
    System.out.println("Fetching... " + url); 
} catch (IOException e) { 
    e.printStackTrace(); 
    System.out.println("Parser connect must have timed out, no results. " + url); 
    fetchFailed[i] = true; 
    continue; 
}  
finally { 
    i++; 
    if (CommonTFUtils.isAllTrue(fetchFailed)) { 
     throw new HttpException("Fetcher failed on every URL of " + response.getSite_name()); 
    } 
} 

と例外がスローさ:

CacheEntry[http://thepiratebay.sx/browse/207/0/7]: updateAvailable=true,lastModified=Tue May 14 14:28:16 BRT 2013,length=-1 
java.io.IOException: stream is closed 
    at sun.net.www.http.ChunkedInputStream.ensureOpen(Unknown Source) 
    at sun.net.www.http.ChunkedInputStream.read(Unknown Source) 
    at java.io.FilterInputStream.read(Unknown Source) 
    at sun.net.www.protocol.http.HttpURLConnection$HttpInputStream.read(Unknown Source) 
    at sun.net.www.protocol.http.HttpURLConnection$HttpInputStream.read(Unknown Source) 
    at sun.net.www.protocol.http.HttpURLConnection$HttpInputStream.read(Unknown Source) 
    at sun.net.www.protocol.http.HttpURLConnection$HttpInputStream.close(Unknown Source) 
    at org.jsoup.helper.HttpConnection$Response.execute(HttpConnection.java:468) 
    at org.jsoup.helper.HttpConnection$Response.execute(HttpConnection.java:410) 
    at org.jsoup.helper.HttpConnection.execute(HttpConnection.java:164) 
    at org.jsoup.helper.HttpConnection.get(HttpConnection.java:153) 
    at com.package.torrent.parser.GenericParser.search(GenericParser.java:147) 
    at com.package.torrent.parser.GenericParser.browse(GenericParser.java:82) 
    at com.package.search.TrackerSearch.searchTracker(TrackerSearch.java:69) 
    at com.package.search.TrackerSearch.searchAllTrackers(TrackerSearch.java:40) 
    at com.package.search.TrackerSearch.searchAllTrackers(TrackerSearch.java:23) 
    at com.package.search.MovieBrowser.browseTrackers(MovieBrowser.java:49) 
    at com.package.ui.browse.BrowseController$MovieBrowserTask.call(BrowseController.java:237) 
    at com.package.ui.browse.BrowseController$MovieBrowserTask.call(BrowseController.java:213) 
    at javafx.concurrent.Task$TaskCallable.call(Task.java:1259) 
    at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source) 
    at java.util.concurrent.FutureTask.run(Unknown Source) 
    at java.lang.Thread.run(Unknown Source) 

誰もがこれを引き起こしている可能性がありますかのアイデアを持っていますに?

ありがとうございます。

+1

これはJSoupの既知の問題です。 https://github.com/jhy/jsoup/issues/336 – Skylion

答えて

2

解決策が見つかりました。 JSoupを呼び出す前にこのコードを配置してください。どうやら、アプレットとWeb Startはこの値をtrueに設定します。さて、Sunが静的でない変数に静的にアクセスする必要があるのは不思議です。

JSoupは、URLがキャッシュされているときにはうまく処理されず、例外として処理されます。

関連する問題