我有一个java编译包与https服务器在网上说话。运行编译会出现以下异常:

javax.net.ssl.SSLException: Unrecognized SSL message, plaintext connection?
    at com.sun.net.ssl.internal.ssl.InputRecord.handleUnknownRecord(Unknown Source)
at com.sun.net.ssl.internal.ssl.InputRecord.read(Unknown Source)
at com.sun.net.ssl.internal.ssl.SSLSocketImpl.readRecord(Unknown Source)
at com.sun.net.ssl.internal.ssl.SSLSocketImpl.performInitialHandshake(Unknown Source)
at com.sun.net.ssl.internal.ssl.SSLSocketImpl.startHandshake(Unknown Source)
at com.sun.net.ssl.internal.ssl.SSLSocketImpl.startHandshake(Unknown Source)
at sun.net.www.protocol.https.HttpsClient.afterConnect(Unknown Source)
at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(Unknown Source)
at sun.net.www.protocol.https.HttpsURLConnectionImpl.connect(Unknown Source)

我认为这是因为与客户端机器建立的连接不安全。是否有任何方法配置本地机器或端口以连接到远程https服务器?


当前回答

如果连接是FTPS test:

FTPSClient ftpClient =新的FTPSClient(协议,false);

protocol = TLS,SSL and false = isImplicit。

其他回答

我认为这是由于联系 与客户端机器建立 不安全。

这是因为您正在与HTTP服务器通信,而不是HTTPS服务器。可能您没有使用正确的HTTPS端口号。

当我在通过代理执行POST请求之前忘记登录公司防火墙时,我得到了同样的错误消息。

如果您使用的是Jetty版本9或更早的版本,则需要将其添加到Jetty 通过

RUN java -jar ${JETTY_HOME}/start.jar --add-to-startd=https

根据这个 Jetty:如何在Jetty客户端使用SSL

从Jetty版本10,它应该工作出来的盒子

以防你在跑步

思科AnyConnect安全移动代理 思科AnyConnect Web安全代理

尝试停止服务。

在我们的公司网络中,这是解决问题的方法。

我得到了同样的错误。这是因为我正在访问https端口使用http..当我将http更改为https时,问题解决了。