我正在编写一个脚本来控制我的灯光,因为我很懒,所以通信是通过电子邮件进行的(我知道它运行得非常快,因为它以前在python上运行,但我用java编写它是出于一些单独的原因)。我知道问题是我一直在收到一封电子邮件 javax.net.ssl.SSLHandshakeException
错误,我尝试了这个溢出页面,但即使我添加了受信任的证书,它也不起作用,并且我不断收到相同的错误。下面是我的代码、完整错误以及显示我已添加证书的图片
import java.util.Properties;
import javax.mail.Folder;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.NoSuchProviderException;
import javax.mail.Session;
import javax.mail.Store;
public class test {
public static void check(String host, String storeType, String user,
String password)
{
try {
//create properties field
Properties properties = new Properties();
properties.put("mail.pop3.host", host);
properties.put("mail.pop3.port", "995");
properties.put("mail.pop3.starttls.enable", "true");
Session emailSession = Session.getDefaultInstance(properties);
//create the POP3 store object and connect with the pop server
Store store = emailSession.getStore("pop3s");
store.connect(host, user, password);
//create the folder object and open it
Folder emailFolder = store.getFolder("INBOX");
emailFolder.open(Folder.READ_ONLY);
// retrieve the messages from the folder in an array and print it
Message[] messages = emailFolder.getMessages();
System.out.println("messages.length---" + messages.length);
for (int i = 0, n = messages.length; i < n; i++) {
Message message = messages[i];
System.out.println("---------------------------------");
System.out.println("Email Number " + (i + 1));
System.out.println("Subject: " + message.getSubject());
System.out.println("From: " + message.getFrom()[0]);
System.out.println("Text: " + message.getContent().toString());
}
//close the store and folder objects
emailFolder.close(false);
store.close();
} catch (NoSuchProviderException e) {
e.printStackTrace();
} catch (MessagingException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
String host = "pop.gmail.com";// change accordingly
String mailStoreType = "pop3";
String username = "EMAIL";// change accordingly
String password = "PASSWORD";// change accordingly
check(host, mailStoreType, username, password);
}
}
错误
javax.mail.MessagingException: Connect failed;
nested exception is:
javax.net.ssl.SSLHandshakeException: No appropriate protocol (protocol is disabled or cipher suites are inappropriate)
at com.sun.mail.pop3.POP3Store.protocolConnect(POP3Store.java:160)
at javax.mail.Service.connect(Service.java:291)
at javax.mail.Service.connect(Service.java:172)
at test.check(test.java:28)
at test.main(test.java:68)
Caused by: javax.net.ssl.SSLHandshakeException: No appropriate protocol (protocol is disabled or cipher suites are inappropriate)
at java.base/sun.security.ssl.HandshakeContext.<init>(HandshakeContext.java:172)
at java.base/sun.security.ssl.ClientHandshakeContext.<init>(ClientHandshakeContext.java:98)
at java.base/sun.security.ssl.TransportContext.kickstart(TransportContext.java:238)
at java.base/sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:434)
at java.base/sun.security.ssl.SSLSocketImpl.ensureNegotiated(SSLSocketImpl.java:904)
at java.base/sun.security.ssl.SSLSocketImpl$AppInputStream.read(SSLSocketImpl.java:995)
at java.base/java.io.BufferedInputStream.fill(BufferedInputStream.java:244)
at java.base/java.io.BufferedInputStream.read(BufferedInputStream.java:263)
at java.base/java.io.DataInputStream.readLine(DataInputStream.java:519)
at com.sun.mail.pop3.Protocol.simpleCommand(Protocol.java:359)
at com.sun.mail.pop3.Protocol.<init>(Protocol.java:101)
at com.sun.mail.pop3.POP3Store.getPort(POP3Store.java:213)
at com.sun.mail.pop3.POP3Store.protocolConnect(POP3Store.java:156)
... 4 more
Process finished with exit code 0
java.security
这是删除tls1并保留tsl 1.1时的错误
Exception in thread "main" java.lang.NoClassDefFoundError: javax/activation/DataSource
at com.sun.mail.pop3.POP3Folder.createMessage(POP3Folder.java:326)
at com.sun.mail.pop3.POP3Folder.getMessage(POP3Folder.java:307)
at javax.mail.Folder.getMessages(Folder.java:943)
at test.check(test.java:35)
at test.main(test.java:68)
Caused by: java.lang.ClassNotFoundException: javax.activation.DataSource
at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:636)
at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:182)
at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:519)
... 5 more
2条答案
按热度按时间kq4fsx7k1#
根据日志,此阶段的问题与验证服务器标识所需的客户端缺少的证书无关。在您的情况下,ssl握手过程中需要解决协议问题或ciper套件不匹配的问题。
没有合适的协议(协议被禁用或密码套件不合适)
正如我所看到的,您正在使用最新版本的java,其中支持较旧版本的tls协议,例如
TLSv1
及TLSv1.1
默认情况下已禁用,因此您可以通过从中删除禁用的来启用它们jdk.tls.disabledAlgorithms
证券交易中的担保财产java.security
配置文件。jdk.tls.disabledalgorithms=sslv3,tlsv1,tlsv1.1,rc4,des,md5withrsa,
dh keysize<1024,ec keysize<224,3des\u ede\u cbc,anon,null
对于较旧版本的java,可以在
JAVA_HOME/jre/lib/security/java.security
对于特定于较新版本和java 16JAVA_HOME/conf/security
nzkunb0c2#
首先要解决的问题是两件事
javax.net.ssl.SSLHandshakeException
必须删除的错误TLSV1
来自java.security文件,就像harry在上面解释的那样。然后您必须将activation.jar文件添加到您的依赖项中,它就会工作。如果这不起作用,请尝试按照这些说明操作