【发布时间】:2013-03-16 04:40:05
【问题描述】:
我有以下代码来下载文件表单 URL
HttpURLConnection urlConn = (HttpURLConnection)urlOfFile.openConnection();
urlConn.setConnectTimeout(5000);
urlConn.setReadTimeout(10000);
StatusInfo.fileSizeTobeDownload = urlConn.getContentLength();
InputStream reader = urlConn.getInputStream();
FileOutputStream writer = new FileOutputStream(downloadFolder+fileName);
byte[] buffer = new byte[1024];
int bytesRead = 0;
while ((bytesRead = reader.read(buffer)) > 0) {
writer.write(buffer, 0, bytesRead);
buffer = new byte[1024];
StatusInfo.fileSizeDownloaded+=bytesRead;
}
writer.close();
reader.close();
此代码运行良好,但有时我收到以下错误:
java.net.SocketTimeoutException: Read timed out
at java.net.SocketInputStream.socketRead0(Native Method)
at java.net.SocketInputStream.read(SocketInputStream.java:146)
at sun.security.ssl.InputRecord.readFully(InputRecord.java:442)
at sun.security.ssl.InputRecord.readV3Record(InputRecord.java:554)
at sun.security.ssl.InputRecord.read(InputRecord.java:509)
at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:850)
at sun.security.ssl.SSLSocketImpl.readDataRecord(SSLSocketImpl.java:807)
at sun.security.ssl.AppInputStream.read(AppInputStream.java:94)
at java.io.BufferedInputStream.fill(BufferedInputStream.java:235)
at java.io.BufferedInputStream.read1(BufferedInputStream.java:275)
at java.io.BufferedInputStream.read(BufferedInputStream.java:334)
at sun.net.www.MeteredStream.read(MeteredStream.java:134)
at java.io.FilterInputStream.read(FilterInputStream.java:133)
at sun.net.www.protocol.http.HttpURLConnection$HttpInputStream.read(HttpURLConnection.java:2582)
at sun.net.www.protocol.http.HttpURLConnection$HttpInputStream.read(HttpURLConnection.java:2577)
没有任何网络中断。有没有其他方法来配置“ReadTimeout”。
【问题讨论】:
-
我不确定,但可能是您的网速太慢,或者可能需要一些时间来响应
-
我们的速度不错,我尝试同时从 3-4 台机器下载它,但在一台机器上失败,每次重试都失败,一段时间后成功下载。
标签: java httpurlconnection socket-timeout-exception