2

我正在编写一个作业,它将通过我的 SOCKS5 代理连接到客户端的 FTP/S 服务器,并且我正在使用 Apache Commons Net 包。问题是我的 SOCKS 代理配置为不需要身份验证,但我仍然收到以下异常:

java.net.SocketException: SOCKS : authentication failed
    at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:443)
    at java.net.Socket.connect(Socket.java:519)

我尝试将 java.net.socks.username 和 password 属性设置为空字符串,但我仍然明白。有没有办法告诉代码不使用身份验证?挖掘底层来源我几乎认为它正在查询代理服务器的身份验证要求,但我不确定。

4

1 回答 1

3

好吧,问题是我的 SOCKS 代理设置要求身份验证,但也接受未经过身份验证的连接。我们使用Dante,虽然像 Filezilla 这样的程序足够聪明,可以遍历所有可接受的身份验证方法,但似乎 java.net 包只使用了提供的第一种方法。由于我的 sockd.conf 文件中的身份验证配置如下:

method: username none
user.notprivileged: nobody

java.net 要求用户名和密码。我只是将方法翻转为“无用户名”,Filezilla 和 java.net 都正确地通过了代理。这有点像 IT 解决方案,但不管怎样让代码工作,对吧?

于 2010-10-21T14:07:32.910 回答