отправка почты с использованием javamail бросает NoSuchMethodError: sun.security.ssl.SessionId.checkLength - PullRequest
0 голосов
/ 19 мая 2018

Мое веб-приложение Java ee 8 использует javamail 1.6.1 для отправки электронной почты через gmail.Я запускаю его на Glassfish 5, Mac OS High Sierra, и Glassfish 5 настроен для работы на jdk1.8.0_20, и я запускаю его из Netbeans 8.2.

Вот фрагмент кода, где это делается:

Properties props = new Properties();
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.starttls.enable", "true");
props.put("mail.smtp.host", host);
props.put("mail.smtp.port", port);

// Get the Session object.
Session session = Session.getInstance(props,
    new javax.mail.Authenticator() {
        @Override
        protected PasswordAuthentication getPasswordAuthentication() {
            return new PasswordAuthentication(username, password);
        }
    });

try {
    Message message = new MimeMessage(session);
    message.setFrom(new InternetAddress(from));
    message.setRecipients(Message.RecipientType.TO, InternetAddress.parse(toEmail));
    message.setSubject("Testing Subject");
    message.setContent(
                "<h1>This message is embedded in HTML tags</h1>",
                "text/html");
    Transport.send(message); // this line throws the exception
} catch (MessagingException e) {
    throw new RuntimeException(e);
}

Строка Transport.send вызывает исключение в названии выше.Точнее:

Caused by: java.lang.NoSuchMethodError: sun.security.ssl.SessionId.checkLength(Lsun/security/ssl/ProtocolVersion;)V
    at sun.security.ssl.HandshakeMessage$ServerHello.<init>(HandshakeMessage.java:504)
    at sun.security.ssl.ClientHandshaker.processMessage(ClientHandshaker.java:209)
    at sun.security.ssl.Handshaker.processLoop(Handshaker.java:984)
    at sun.security.ssl.Handshaker.process_record(Handshaker.java:919)
    at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:1043)
    at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1343)
    at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1371)
    at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1355)
    at com.sun.mail.util.SocketFetcher.configureSSLSocket(SocketFetcher.java:619)
    at com.sun.mail.util.SocketFetcher.startTLS(SocketFetcher.java:546)
    at com.sun.mail.smtp.SMTPTransport.startTLS(SMTPTransport.java:2135)
    at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:738)
    at javax.mail.Service.connect(Service.java:388)
    at javax.mail.Service.connect(Service.java:246)
    at javax.mail.Service.connect(Service.java:195)
    at javax.mail.Transport.send0(Transport.java:254)
    at javax.mail.Transport.send(Transport.java:124)

Я нашел этот подобный вопрос здесь , но все, что они говорят, это убедиться, что Glassfish работает на JDK 1.8, а у меня -

Я заметил, что один и тот же класс javax.mail.Transport существует в обеих зависимостях, javaee-api и javamail, поэтому я удалил javamail из своих зависимостей в моем pom.xml и смог все еще собрать приложение, но получил ту же ошибку при попыткеотправьте письмо.

Вот как выглядит мой pom.xml:

    <dependency>
        <groupId>javax</groupId>
        <artifactId>javaee-api</artifactId>
        <version>8.0</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>com.sun.mail</groupId>
        <artifactId>javax.mail</artifactId>
        <version>1.6.1</version>
    </dependency>

Ответы [ 2 ]

0 голосов
/ 13 ноября 2018

Понижение рейтинга JDK не рекомендуется.Я нашел другое решение, которое сработало для меня.См. Ответ Антуана в sun.security.ssl.SSLSessionImpl не найдено .Вы можете удалить пакеты sun. * Из соответствующего файла с помощью утилиты zip, такой как 7ZIP.

Я не пробовал это конкретное сообщение об ошибке, но подозреваю, что это будет решением, так как, похоже, существует многопохожие вопросы, связанные с этим пакетом с той же основной причиной.

0 голосов
/ 21 мая 2018

Я обновил JDK 8 до 1.8.0_172 и начал получать эту другую ошибку:

NoSuchMethodError: sun.security.ssl.SSLSessionImpl.<init>(Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/CipherSuite;Ljava/util/Collection;Lsun/security/ssl/SessionId;Ljava/lang/String;I)V

Это очевидно проблема со Glassfish 5, как обсуждалось здесь .

Итак, я понизил версию JDK 8 до версии 1.8.0_152, что решило эту проблему.

Чтобы настроить netbeans для использования правильного обновления jdk, настройте его в файле netbeans_home/etc/netbeans.conf:

netbeans_jdkhome=/Library/Java/JavaVirtualMachines/jdk1.8.0_152.jdk/Contents/Home
...