我正在使用apache commons-net 3.6库来连接FTPS服务器。 FTPS服务器是第三方NAT的后面。我无法更改服务器端的任何设置。 我可以登录到服务器,但无法列出文件。我已经尝试了一些公共FTP和FTPS服务器的相同代码,结果是成功的。似乎他们不在NAT之后。但是filezilla可以成功连接并列出我有问题的服务器上的文件。 有我的代码
ftps.connect(server, port);
System.out.println("Connected to " + server + ".");
reply = ftps.getReplyCode();
ftps.enterLocalPassiveMode();
if (!FTPReply.isPositiveCompletion(reply)) {
ftps.disconnect();
System.err.println("FTP server refused connection.");
System.exit(1);
}
if (!ftps.login(username, password)) {
ftps.logout();
}
// ftps.setEnabledSessionCreation(false);
ftps.feat();
ftps.execPBSZ(0);
ftps.execPROT("P");
ftps.setFileType(FTP.BINARY_FILE_TYPE);
FTPFile dirs[] = ftps.listDirectories();
还有我的ftps日志:
220 FTP Server ready.
AUTH TLS
234 AUTH TLS successful
Connected to x.x.x.x
USER *******
331 Password required for azercell
PASS *******
230 User myuser logged in
FEAT
211-Features:
MDTM
MFMT
LANG bg-BG;en-US;fr-FR;it-IT;ja-JP;ko-KR;ru-RU;zh-CN;zh-TW
TVFS
UTF8
AUTH TLS
MFF modify;UNIX.group;UNIX.mode;
MLST modify*;perm*;size*;type*;unique*;UNIX.group*;UNIX.mode*;UNIX.owner*;
PBSZ
PROT
REST STREAM
SIZE
211 End
PBSZ 0
200 PBSZ 0 successful
PROT P
200 Protection set to Private
TYPE I
200 Type set to I
SYST
215 UNIX Type: L8
PASV
227 Entering Passive Mode (192,168,2,50,192,12).
[Replacing PASV mode reply address 192.168.2.50 with x.x.x.x]
LIST
150 Opening BINARY mode data connection for file list
425 Unable to build data connection: Operation not permitted
我读过版本3.6之前的公共网络库以前无法正确处理NAT连接。
任何人都可以帮助我吗?我的代码出了什么问题?
答案 0 :(得分:2)
所以我的结论是问题与NAT技术无关,apache-commons 3.6无法正确处理所有FTPS选项。正如我之前提到的,我们与第三方集成并且无法更改FTPS设置,至少我们安装了filezilla ftp服务器并且能够重现错误。幸运的是,我在Luke Hansen的http://eng.wealthfront.com/2016/06/10/connecting-to-an-ftps-server-with-ssl-session-reuse-in-java-7-and-8/找到了解决方案。非常感谢他