我有一个客户端/服务器应用程序,它通过 Java 的 SSLSocket 远程连接到服务器。
我正在尝试实现一种可选模式,该模式通过经过身份验证的 SOCKS v5 代理启用连接。
我尝试使用相关教程,但没有具体提及 SSL。
我试过设置系统范围的属性(“socksProxyHost”和“socksProxyPort”),但它似乎没有做任何事情。
我的下一个方法是在 SSLSocketFactory 中使用工厂方法:
String proxyHost = Config.prefs.get("PROXY_NAME", "localhost");
int proxyPort = Config.prefs.getInt("PROXY_PORT", 1080);
InetSocketAddress proxyAddr = new InetSocketAddress(proxyHost, proxyPort);
Socket underlying = new SSLSocket(new Proxy(Proxy.Type.SOCKS, proxyAddr));
underlying.connect(new InetSocketAddress(getHost(), getPort()));
socket = (SSLSocket) factory.createSocket(
underlying,
getHost(),
getPort(),
true);
但是这种方法的问题是 createSocket 方法要求底层套接字已经连接,并且我的服务器不会接受非 SSL 连接。
使用 SOCKS 连接到远程服务器的最佳方式是什么?此外,我几乎不知道如何在这个系统中为经过身份验证的 SOCKS 提供用户名/密码。
谢谢!