java - 将自定义信任库添加到 java 中的 imaps

标签 java ssl imap truststore

我使用 SMTP 发送邮件并使用 imaps (imap + ssl) 检索邮件:

我做的内部连接方法:

private Session connect(SMTPTask task) {

    SSLSocketFactory factory = null;
    try {
        SSLContext ctx;
        KeyManagerFactory kmf;
        KeyStore ks;
        char[] passphrase = "changeit".toCharArray();

        ctx = SSLContext.getInstance("TLS");
        kmf = KeyManagerFactory.getInstance("SunX509");
        ks = KeyStore.getInstance("JKS");

        ks.load(new FileInputStream("truststore.jks"), passphrase);

        kmf.init(ks, passphrase);
        ctx.init(kmf.getKeyManagers(), null, null);

        factory = ctx.getSocketFactory();
    } catch (Exception e) {
        log.error("Error with SSLFactory",e);
    }

    String host = getHost();
    String port = String.valueOf(getPort());

    Authenticator authenticator = new Authenticator(task);


    Properties properties = new Properties();
    properties.setProperty("mail.smtp.submitter", authenticator.getPasswordAuthentication().getUserName());
    properties.setProperty("mail.smtp.auth", "true");
    //properties.setProperty("mail.imap.auth.login.disable", "true");
    properties.setProperty("mail.smtp.host", host);
    properties.setProperty("mail.smtp.port", port);
    properties.put("mail.imaps.ssl.socketFactory", factory);
    properties.setProperty("mail.imap.port", "993");

    Properties systemProps = System.getProperties();
    systemProps.put( "javax.net.ssl.trustStore", "truststore.jks");
    systemProps.put( "javax.net.ssl.trustStorePassword", "changeit");
    System.setProperties(systemProps);

    return Session.getInstance(properties, authenticator);

还有我在其他地方做的:

...
store.connect(getHost(),getUser(),getPass());
...

编辑: 在这里我得到以下异常:

PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target

现在我想添加一个带有自己证书的自定义信任库。另一篇文章展示了如何在 Java 中执行此操作:Add trustStore for client authentication

但是我怎样才能将 SSLSocketFactory 与我的 Store 结合起来呢?所以我的商店使用自定义 ssl 连接?

正确的做法是什么?如果那不可能,是否有另一种方法可以将我的信任库添加到 Java 中的商店?

编辑:我遗漏了什么,或者我在属性中做错了什么?

问候

最佳答案

您通过用于创建 Session 的属性映射传入套接字工厂

Properties props = new Properties();
// other properties as usual
props.put("mail.imaps.ssl.socketFactory", new MyCustomSSLSocketFactory());
Session sess = Session.getInstance(props);

请参阅 com.sun.mail.imap package summary 底部的表格了解全部详情。

关于java - 将自定义信任库添加到 java 中的 imaps,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14787294/

相关文章:

postgresql - 如何使用 CLI for Cloud Composer 添加 SSL postgres 连接?

linux - 如何在没有证书(Apache VirtualHosts)的情况下将 HTTPS 请求重定向到 HTTP 并避免证书警告

linux - 成熟的 IMAP 库

IMAP - ENVELOPE 与 RFC822 header 、获取整个消息与正文部分等

java - 使用 SecureRandom 生成 AES key 和 IV 的替代方案

java - 隐藏没有 child 的组 - ExpandableListView

java - 在字节好友中生成参数注解

java - 免费的 AOT Java 编译器

java - 如何禁用 javamail SSL 支持?

java - 使用spring集成IMAP适配器,如何手动获取标记为 "unread"的电子邮件?