我怀疑在我的代码中设置套接字超时的位置。我想要实现的是,当创建套接字时,超时应为10秒。所以我在握手之前设置它。现在我在日志中看到的错误有两种。 1)连接超时错误和2)读取超时错误。所以我想知道是否有人可以向我解释更多关于在何处设置超时。我有以下代码:
try{
SSLSocketFactory factory=(SSLSocketFactory)SSLSocketFactory.getDefault();
socket = (SSLSocket)factory.createSocket(host,port);
socket.setSoTimeout(10000);
socket.startHandshake();
OutputStream socketOut =( socket.getOutputStream() );
String command = method+" "+path+" HTTP/1.0\n";
//command+="Host: "+host+"\nConnection: close\n";
if (data!=null) {
command+="Content-Length: " + data.length +"\n\n";
sendBytes.write(command.getBytes(),0,command.length());
sendBytes.write(data,0,data.length);
} else {
// if data == null then we are most likely doing a GET request
sendBytes.write(command.getBytes(),0,command.length());
}
sendBytes.write("\n".getBytes(),0,"\n".length());
temp = sendBytes.toByteArray();
socketOut.write(temp,0,temp.length);
socketOut.flush();
/* read response */
BufferedInputStream socketIn =
new BufferedInputStream( socket.getInputStream() );
byte[] inputData = new byte[READSIZE];
while ((bytesRead=socketIn.read(inputData,0,READSIZE)) > -1) {
receiveBytes.write(inputData,0,bytesRead);
}
result=receiveBytes.toByteArray();
//receiveBytes.close();
//sendBytes.close();
//socket.close();
} catch (Exception e) {
throw e;
}finally {
try { receiveBytes.close(); sendBytes.close(); socket.close(); } catch (Exception ee) {}
}
return result;
} // end submit
} // end class
请让我知道如何让超时工作至少完成。在日志中,错误发生在18秒(不应该是这种情况),而不是10秒。
由于
答案 0 :(得分:2)
问题很可能是在创建套接字时连接时已经发生超时。尝试首先使用无参数工厂方法实例化未连接的套接字,然后使用timeout
除Socket#setSoTimeout
之外的{{1}}选项。后者只是为这些行动而努力
的ServerSocket.accept()
SocketInputStream.read()
DatagramSocket.receive()
但在连接尝试期间不处理超时。
有关详细信息,另请参阅Socket#connect。