当前位置: 首页 > 知识库问答 >
问题:

javax。邮政MessaginException:无法将套接字转换为TLS

陆翔飞
2023-03-14

我有另一个转换套接字异常。Stackoverflow将我和相关答案联系起来,我已经做了人们建议的所有事情。

这里有异常描述:

线程“main”javax中出现异常。邮政MessaginException:无法将套接字转换为TLS;嵌套的例外是:java。网SocketException:java。安全NoSuchAlgorithmException:在com上构造实现时出错(算法:Default,提供程序:SunJSSE,类:
sun.security.ssl.SSLContextImpl$DefaultSSLContext)。太阳邮政smtp。SMTP运输。com上的startTLS(SMTPTransport.java:1880)。太阳邮政smtp。SMTP运输。javax上的protocolConnect(SMTPTransport.java:648)。邮政服务在XMailMessenger上连接(Service.java:295)。MailMessenger。alfa的sendMail(MailMessenger.java:414)。跑步者main(runner.java:38)由:java引起。网SocketException:java。安全NoSuchAlgorithmException:Error
在javax上构造实现(算法:Default,提供程序:SunJSSE,类:sun.security.ssl.SSLContextImpl$DefaultSSLContext)。网ssl。默认SSLSocketFactory。javax中的throwException(未知源)。网ssl。默认SSLSocketFactory。在com上创建套接字(未知源)。太阳邮政util。SocketFetcher。com上的startTLS(SocketFetcher.java:432)。太阳邮政smtp。SMTP运输。startTLS(SMTPTransport.java:1875)。。。4更多原因:java。安全NoSuchAlgorithmException:在java上构造实现时出错(算法:默认,提供程序:SunJSSE,类:
sun.security.ssl.SSLContextImpl$DefaultSSLContext)。安全提供商$服务。sun上的newInstance(未知源)。安全jca。GetInstance。sun上的getInstance(未知源)。安全jca。GetInstance。javax上的getInstance(未知源)。网ssl。SSLContext。javax上的getInstance(未知源)。网ssl。SSLContext。javax上的getDefault(未知源)。网ssl。SSLSocketFactory。com上的getDefault(未知源)。太阳邮政util。SocketFetcher。startTLS(SocketFetcher.java:427)。。。5更多原因:java。lang.NullPointerException在sun。安全ssl。KeyManagerFactoryImpl$SunX509。javax上的engineInit(未知源)。网ssl。KeyManager工厂。在太阳上初始化(未知源)。安全ssl。SSLContextImpl$DefaultSSLContext。getDefaultKeyManager(未知源)。安全ssl。SSLContextImpl$DefaultSSLContext。(未知来源)太阳。反映NativeConstructorAccessorImpl。sun上的newInstance0(本机方法)。反映NativeConstructorAccessorImpl。sun上的newInstance(未知源)。反映DelegatingConstructorAccessorImpl。java上的newInstance(未知源)。郎。反思。构造函数。java上的newInstance(未知源)。lang.Class。newInstance(未知源)。。。12个以上

所以我决定写两个额外的类:

      package XMailMessenger;

     import javax.net.ssl.X509TrustManager;
     import java.security.cert.X509Certificate;
     /**
      * @author Raminderjeet Singh
      */
      public class DummyTrustManager implements X509TrustManager {

      public void checkClientTrusted(X509Certificate[] cert, String authType) {
    // everything is trusted


   }

    public void checkServerTrusted(X509Certificate[] cert, String authType) {
   // everything is trusted
   }

   public X509Certificate[] getAcceptedIssuers() {
      return new X509Certificate[0];
   }
   }

第二个是:

 package XMailMessenger;

  import java.io.IOException;
  import java.net.InetAddress;
  import java.net.Socket;

  import javax.net.SocketFactory;
   import javax.net.ssl.*;

  /**
  * @author Raminderjeet Singh
 */
  public class DummySSLSocketFactory extends SSLSocketFactory {
   private SSLSocketFactory factory;

    public DummySSLSocketFactory() {
try {
    SSLContext sslcontext = SSLContext.getInstance("TLS");
    sslcontext.init(null,
             new TrustManager[] { new DummyTrustManager()},
             null);
    factory = (SSLSocketFactory)sslcontext.getSocketFactory();
} catch(Exception ex) {
    // ignore
}
}

public static SocketFactory getDefault() {
return new DummySSLSocketFactory();
}

public Socket createSocket() throws IOException {
return factory.createSocket();
}

public Socket createSocket(Socket socket, String s, int i, boolean flag)
            throws IOException {
return factory.createSocket(socket, s, i, flag);
}

   public Socket createSocket(InetAddress inaddr, int i,
            InetAddress inaddr1, int j) throws IOException {
return factory.createSocket(inaddr, i, inaddr1, j);
    }

   public Socket createSocket(InetAddress inaddr, int i)
            throws IOException {
 return factory.createSocket(inaddr, i);
   }

  public Socket createSocket(String s, int i, InetAddress inaddr, int j)
            throws IOException {
  return factory.createSocket(s, i, inaddr, j);
   }

  public Socket createSocket(String s, int i) throws IOException {
  return factory.createSocket(s, i);
  }

  public String[] getDefaultCipherSuites() {
  return factory.getDefaultCipherSuites();
  }

    public String[] getSupportedCipherSuites() {
        return factory.getSupportedCipherSuites();
   }
  }

最后,我们有了发送邮件的方法:

        Properties props = new Properties();
    props.put("mail.smtp.host", currentSettingsDocument.getSMTPHostServer());
    props.put("mail.smtp.user", currentSettingsDocument.getLogin());
    props.put("mail.smtp.password", currentSettingsDocument.getPassword());
    props.put("mail.smtp.port", "465");
    props.put("mail.smtp.auth", "true");
    props.put("mail.smtp.timeout" , "3000");
    props.put("mail.smtp.starttls.enable", "false");
    props.put("mail.smtp.socketFactory.port", "465");

    props.put("mail.smtp.socketFactory.fallback", "false");
    props.put("mail.smtp.ssl.trust", "smtp.gmail.com");
    props.put("javax.net.debug","ssl,session");

    // Required to avoid security exception.
        Authenticator authentication = new Authenticator() {
          protected PasswordAuthentication getPasswordAuthentication() {
             return new PasswordAuthentication(currentSettingsDocument.getLogin() , 
            currentSettingsDocument.getPassword());  
          }
         };
    Session session = Session.getInstance(props, authentication);
    // create some properties and get the default Session

    // create a message
    MimeMessage msg = new MimeMessage(session);

    // set the from and to address
    InternetAddress addressFrom = new    


       InternetAddress(currentSettingsDocument.getSenderMail());
   msg.setFrom(addressFrom);


       for(InternetAddress addr: recepients )
        msg.addRecipient(Message.RecipientType.TO, addr );

    // Optional : You can also set your custom headers in the Email if you
    // 
    // msg.addHeader("MyHeaderName", "myHeaderValue");

    // Setting the Subject and Content Type
    msg.setContent("1111", "text/plain");
    Transport transport = session.getTransport("smtp");
            Document.getSMTPHostServer(), Document.getPassword());
    transport.connect(currentSettingsDocument.getSMTPHostServer(), 465,                                 
    transport.sendMessage(msg, msg.getAllRecipients());
    transport.close();

调用sendMessage后,我得到异常:

2013年5月18日下午5:36:18 XMailMessenger。MailMessenger sendMail严重:null javax。邮政MessaginException:异常读取响应;嵌套的例外是:java。网SocketTimeoutException:读取超时

PS谷歌邮件正常工作

共有1个答案

慕迪
2023-03-14

该异常是由旧Windows(XP、Vista)上不受支持的TLS引起的,并由类SocketFetcher(包com.sun.mail.util;)引发at线路

MailSSLSocketFactory msf = new MailSSLSocketFactory();

MailSSLSocketFactory(同一个包)/***初始化一个新的MailSSLSocketFactory。**@抛出GeneralSecurityException*/public-mailssocketFactory()抛出GeneralSecurityException{this(“TLS”);}

 类似资料:
  • 我用Javax发送邮件有问题。我们使用gmail大约4年了,用我们的Java软件发送邮件。现在我得到了以下错误: 以下是我的gmail设置: 我还尝试了其他邮件服务器(O365、Strato),但收到了相同的错误。

  • 使用JavaMail通过SMTP(STARTTLS)发送消息时,会引发以下异常: 这里(关于stackoverflow)和其他地方的多个帖子表明邮件传输会话的一些属性,即 在解决这个问题中发挥作用,但我尝试了所有这些参数的组合(存在/不存在),没有一个能解决问题。 有人知道如何解决这个问题吗? 其他信息/详细信息: Java版本:1.6.0 JavaMail版本:1.5.2 邮件传输会话的属性:

  • 我已经将证书导入了cacerts(JAVA\u HOME指向的地方),但仍然出现了这个错误。无法解决问题。客户端的邮件服务器(Microsoft ESMTP服务器)没有防火墙问题。我可以从我的服务器远程登录。已尝试SSLpoke,但超时。试过25号端口的tcpdump,可以看到来回的通信。基本上是试图触发来自邮件服务器的出站电子邮件。 详细的错误日志为: 原因:javax。邮政MessaginEx

  • 在一个应用程序中,我使用java实现了邮件发送逻辑。我使用了smtp.gmail。com587端口,具有有效的gmail id和密码。在开发环境中,一切正常。但在生产环境中,我需要使用不同的邮件服务器,例如smtp.xyz。在端口25上输入有效的电子邮件id和密码。 当我继续使用以下代码启用SSL时: 我出错了

  • 我在使用Apache Commons Mail连接到SMTP服务器时遇到问题。我已经尝试了所有方法,但我唯一能在网上找到的是Java邮件。这是我的错误: 原因:javax.mail.MessagingException:无法将套接字转换为TLS;嵌套异常是:javax.net.ssl.SSLHandshakeException:sun.security.validator.ValidatorExc

  • 我正在尝试通过Gmail SMTP服务器使用JavaMail发送电子邮件。代码如下: 返回此错误: 无法将套接字转换为TLS; 完整的堆栈跟踪: 异常线程"main"javax.mail.RuntimeException:ervice.connectMessagingException:无法将套接字转换为TLS;嵌套异常是:ervice.java:176SSLHandshakeException: