我需要握手。我用下面的代码来做。
我在applet中运行代码,直接针对服务器运行时工作正常。当相同的代码通过代理运行时,我遇到的问题。 我正在寻找跟踪级别为5的java控制台。直接在代码行“SSLSocket socket =(SSLSocket)factory.createSocket(”www.theserver.com“,443);”被执行 此行显示在java控制台“network:Connecting http://www.theserver.com:443 with proxy = DIRECT”中。在此之后,applet停止工作。我认为这是因为 代理不允许端口443上的http流量。
任何人都可以告诉我为什么它使用http进行连接以及我应该怎么做才能使用https进行连接?
import javax.net.ssl.HandshakeCompletedEvent;
import javax.net.ssl.HandshakeCompletedListener;
import javax.net.ssl.SSLSocket;
import javax.net.ssl.SSLSocketFactory;
public class Handshake
{
class MyHandshakeListener implements HandshakeCompletedListener
{
public void handshakeCompleted(HandshakeCompletedEvent e)
{
System.out.println("Handshake succesful!");
System.out.println("Using cipher suite: " + e.getCipherSuite());
}
}
public void DoHandshake()
{
try
{
SSLSocketFactory factory = (SSLSocketFactory) SSLSocketFactory.getDefault();
SSLSocket socket = (SSLSocket) factory.createSocket("www.theserver.com", 443);
String[] suites = socket.getSupportedCipherSuites();
socket.setEnabledCipherSuites(suites);
socket.addHandshakeCompletedListener(new MyHandshakeListener());
socket.startHandshake();
}
catch (Exception e)
{
System.out.println(e);
}
}
}
答案 0 :(得分:0)
我知道这有点晚了,但我们遇到了完全相同的问题并且能够解决它。问题出在客户端上,在Java控制面板的高级选项卡上检查了“使用SSL 2.0兼容的ClientHello格式”。取消选中客户端上的此框,它将正确连接。