javax.net.ssl.SSLException по запросу HttpsURLConnection
Я пытаюсь вызвать URL-адрес https внутри моего Java-приложения сразу после переименования файла в каталоге FTP-сервера.
Файл переименован, и запрос https URL успешен, однако я получаю странное исключение, связанное с сертификатом, импортированным в мой файл cacerts.
Код, который переименовывает файл в каталог ftp и затем делает запрос https url, выглядит следующим образом:
...
FTPClient client = null;
try {
client = Ftp4jUtility.ftpsConnect1(SERVER_MACHINE, PORT, SERVER_USERNAME, SERVER_PASSWORD);
client.rename(oldDir, newDir);
renameStatus=true;
String url = config.getExtractZipUrl()+stdDet.getStudyDetailsCaseId(tmpNewFile.trim());
try {
JavaHttpsUrlConnectionReader(url);
} catch (Exception ex) {
Logger.getLogger(TranferFileFtp4j.class.getName()).log(Level.ERROR, null, ex);
}
client.logout();
client.disconnect(true);
} catch (IllegalStateException ex) {
log.info("Failed to rename: " + oldDir);
Logger.getLogger(TranferFileFtp4j.class.getName()).log(Level.ERROR, null, ex);
} catch (IOException | FTPIllegalReplyException | FTPException ex) {
log.info("Failed to rename: " + oldDir);
Logger.getLogger(TranferFileFtp4j.class.getName()).log(Level.ERROR, null, ex);
} finally {
if (client.isConnected()) {
try {
try {
client.logout();
client.disconnect(true);
} catch (IllegalStateException | FTPIllegalReplyException | FTPException ex) {
Logger.getLogger(TranferFileFtp4j.class.getName()).log(Level.ERROR, null, ex);
}
} catch (IOException ex) {
Logger.getLogger(TranferFileFtp4j.class.getName()).log(Level.ERROR, null, ex);
}
}
}
return renameStatus;
В моем журнале я обнаруживаю:
2015-03-05 13:09:04 ERROR TranferFileFtp4j:398 -
javax.net.ssl.SSLException: Unsupported record version Unknown-53.49
at sun.security.ssl.InputRecord.checkRecordVersion(InputRecord.java:552) at sun.security.ssl.InputRecord.checkRecordVersion(InputRecord.java:552)
at sun.security.ssl.InputRecord.readV3Record(InputRecord.java:565)
at sun.security.ssl.InputRecord.read(InputRecord.java:532)
at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:954)
at sun.security.ssl.SSLSocketImpl.readDataRecord(SSLSocketImpl.java:911)
at sun.security.ssl.AppInputStream.read(AppInputStream.java:105)
at sun.nio.cs.StreamDecoder.readBytes(StreamDecoder.java:284)
at sun.nio.cs.StreamDecoder.implRead(StreamDecoder.java:326)
at sun.nio.cs.StreamDecoder.read(StreamDecoder.java:178)
at sun.nio.cs.StreamDecoder.read0(StreamDecoder.java:127)
at sun.nio.cs.StreamDecoder.read(StreamDecoder.java:112)
at java.io.InputStreamReader.read(InputStreamReader.java:168)
at it.sauronsoftware.ftp4j.NVTASCIIReader.readLine(NVTASCIIReader.java:105)
at it.sauronsoftware.ftp4j.FTPCommunicationChannel.read(FTPCommunicationChannel.java:142)
at it.sauronsoftware.ftp4j.FTPCommunicationChannel.readFTPReply(FTPCommunicationChannel.java:187)
at it.sauronsoftware.ftp4j.FTPClient.disconnect(FTPClient.java:1133)
at com.npap.network.TranferFileFtp4j.renameFileFtps1(TranferFileFtp4j.java:390)
at com.npap.utils.ProcessDicomFiles.sendZippFiles(ProcessDicomFiles.java:195)
at com.npap.scheduler.MainJob.execute(MainJob.java:84)
at org.quartz.core.JobRunShell.run(JobRunShell.java:202)
at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:573)
2015-03-05 13:09:04 ERROR TranferFileFtp4j:415 -
java.lang.IllegalStateException: Client not authenticated
at it.sauronsoftware.ftp4j.FTPClient.logout(FTPClient.java:1406)
at com.npap.network.TranferFileFtp4j.renameFileFtps1(TranferFileFtp4j.java:412)
at com.npap.utils.ProcessDicomFiles.sendZippFiles(ProcessDicomFiles.java:195)
at com.npap.scheduler.MainJob.execute(MainJob.java:84)
at org.quartz.core.JobRunShell.run(JobRunShell.java:202)
at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:573)
и вот также код (довольно простой), который делает запрос URL https:
public void JavaHttpsUrlConnectionReader(String myUrl) throws Exception {
URL url = null;
BufferedReader reader = null;
StringBuilder stringBuilder;
try {
url = new URL(myUrl);
HttpsURLConnection connection = (HttpsURLConnection) url.openConnection();
// just want to do an HTTP GET here
connection.setRequestMethod("GET");
// give it 15 seconds to respond
connection.setReadTimeout(15*1000);
connection.connect();
// read the output from the server
reader = new BufferedReader(new InputStreamReader(connection.getInputStream()));
stringBuilder = new StringBuilder();
String line = null;
while ((line = reader.readLine()) != null)
{
stringBuilder.append(line + "\n");
}
//return stringBuilder.toString();
}
catch (Exception e)
{
e.printStackTrace();
throw e;
}
finally
{
// close the reader; this can throw an exception too, so
// wrap it in another try/catch block.
if (reader != null)
{
try
{
reader.close();
}
catch (IOException ioe)
{
ioe.printStackTrace();
}
}
}
}
Почему я получаю:
javax.net.ssl.SSLException: Unsupported record version Unknown-53.49
at sun.security.ssl.InputRecord.checkRecordVersion(InputRecord.java:552) at sun.security.ssl.InputRecord.checkRecordVersion(InputRecord.java:552)
и если вы проверите дальше вниз:
java.lang.IllegalStateException: Client not authenticated
at it.sauronsoftware.ftp4j.FTPClient.logout(FTPClient.java:1406)
на самом деле строка 390 в моем коде, указанном в журнале, - это то, где я пытаюсь:
client.disconnect (истина);
Таким образом, я получаю исключение, в то время как я пытаюсь отключиться от сеанса FTP. У кого-нибудь есть идея, почему я получаю это исключение?
2 ответа
Наконец-то кажется, что
client.logout();
до:
client.disconnet(true);
вызывал исключение:
java.lang.IllegalStateException: Client not authenticated
at it.sauronsoftware.ftp4j.FTPClient.logout(FTPClient.java:1406)
:
javax.net.ssl.SSLException: Unsupported record version Unknown-53.49
at sun.security.ssl.InputRecord.checkRecordVersion(InputRecord.java:552) at sun.security.ssl.InputRecord.checkRecordVersion(InputRecord.java:552)
произошел из-за запроса https (HttpsURLConnection) с недостаточным readTimeOut:
HttpsURLConnection connection = (HttpsURLConnection) url.openConnection();
connection.setRequestMethod("GET");
connection.setReadTimeout(15*1000);
connection.connect();
15 секунд было недостаточно. Увеличено до 60 и это было решено...
Какую версию Java вы используете? Может быть, вы можете попробовать JCE