• 解决java发邮件错误javax.net.ssl.SSLHandshakeException: No appropriate protocol


    java发送邮件时报以下错误信息:
    javax.net.ssl.SSLHandshakeException: No appropriate protocol (protocol is disabled or cipher

    1. [com.bm6api.controller.v1.AppUserController] - sendLoginAuthCodeMail 发送登录验证码邮件 : {"code":200,"info":"Success"}
    2. [org.springframework.web.servlet.mvc.method.annotation.RequestResponseBodyMethodProcessor] - Written [{"code":200,"info":"Success"}] as "text/html" using [org.springframework.http.converter.StringHttpMessageConverter@3c3f40cb]
    3. [org.springframework.web.servlet.DispatcherServlet] - Null ModelAndView returned to DispatcherServlet with name 'SpringMVC': assuming HandlerAdapter completed request handling
    4. [org.springframework.web.servlet.DispatcherServlet] - Successfully completed request
    5. [freemarker.cache] - TemplateLoader.findTemplateSource("email_login_auth_en_US.ftl"): Not found
    6. [freemarker.cache] - TemplateLoader.findTemplateSource("email_login_auth_en.ftl"): Not found
    7. [freemarker.cache] - TemplateLoader.findTemplateSource("email_login_auth.ftl"): Found
    8. [freemarker.cache] - "email_login_auth.ftl"("en_US", UTF-8, parsed): using cached since
    9. javax.mail.MessagingException: Could not connect to SMTP host: smtp.exmail.qq.com, port: 465;
    10. nested exception is:
    11. javax.net.ssl.SSLHandshakeException: No appropriate protocol (protocol is disabled or cipher suites are inappropriate)
    12. at com.sun.mail.smtp.SMTPTransport.openServer(SMTPTransport.java:1963)
    13. at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:654)
    14. at javax.mail.Service.connect(Service.java:345)
    15. at javax.mail.Service.connect(Service.java:226)
    16. at javax.mail.Service.connect(Service.java:246)
    17. at com.bm6api.service.impl.MailServiceImpl.sendEmail(MailServiceImpl.java:92)
    18. at com.bm6api.thread.EmailSendThread.run(EmailSendThread.java:34)
    19. Caused by: javax.net.ssl.SSLHandshakeException: No appropriate protocol (protocol is disabled or cipher suites are inappropriate)
    20. at sun.security.ssl.HandshakeContext.(HandshakeContext.java:171)
    21. at sun.security.ssl.ClientHandshakeContext.(ClientHandshakeContext.java:106)
    22. at sun.security.ssl.TransportContext.kickstart(TransportContext.java:238)
    23. at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:410)
    24. at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:389)
    25. at com.sun.mail.util.SocketFetcher.configureSSLSocket(SocketFetcher.java:528)
    26. at com.sun.mail.util.SocketFetcher.createSocket(SocketFetcher.java:333)
    27. at com.sun.mail.util.SocketFetcher.getSocket(SocketFetcher.java:208)
    28. at com.sun.mail.smtp.SMTPTransport.openServer(SMTPTransport.java:1927)
    29. ... 6 more

    解决办法1

    修改JDK配置,将TLSv1和TLSv1.1从配置项里去除。配置文件路径在

    $JAVA_HOME/jre/lib/security/java.security

    定位到配置文件的

    jdk.tls.disabledAlgorithms=SSLv3, TLSv1, TLSv1.1, RC4, DES, MD5withRSA

    所在行,注释掉原来那行,复制到下方,去掉TLSv1和TLSv1.1,保存。

    1. # Note: This property is currently used by the JDK Reference implementation.
    2. # It is not guaranteed to be examined and used by other implementations.
    3. #
    4. # Example:
    5. # jdk.tls.disabledAlgorithms=MD5, SSLv3, DSA, RSA keySize < 2048, \
    6. # rsa_pkcs1_sha1
    7. #jdk.tls.disabledAlgorithms=SSLv3, TLSv1, TLSv1.1, RC4, DES, MD5withRSA, \
    8. jdk.tls.disabledAlgorithms=SSLv3, RC4, DES, MD5withRSA, \
    9. DH keySize < 1024, EC keySize < 224, 3DES_EDE_CBC, anon, NULL, \
    10. include jdk.disabled.namedCurves

    重新运行你自己的java服务进程即可。

  • 相关阅读:
    复旦大学:邮件系统安全运维实用建议
    Spring编程常见错误50例-Spring Bean依赖注入常见错误(上)
    经典案例|使用Supabase解决可视化大屏项目的常见问题
    安装 paddlepaddle paddleocr库,避坑指南
    在Linux上配置Spug自动化运维平台,实现公网远程访问
    力扣(LeetCode)16. 最接近的三数之和(C++)
    能带你起飞的【数据结构】成王第十二篇:堆2
    05. DataTemplate
    2023最新SSM计算机毕业设计选题大全(附源码+LW)之java焦作旅游网站q5msq
    集合框架----源码解读LikedeHashMap篇
  • 原文地址:https://blog.csdn.net/long690276759/article/details/134404652