Java连接FTP成功,但是上传是失败,报错:Connected time out

时间:2022-06-28 03:05:22

Java代码在本机上传文件到FTP服务器的时候成功,但是部署到测试服务器的时候出现,连接FTP成功但是上传失败,并且报Connected time out错误;

测试服务器和FTP服务都在阿里云上;(使用内网外网连接都有错)

原因:

  网上找资料原因可能是防火墙策略阻止了java测试服务的端口连接,FTP服务器使用的有可能是被动模式;

  注意:

1.FTP的PORT(主动模式)和PASV(被动模式)

(1) PORT(主动模式)

PORT中文称为主动模式,工作的原理: FTP客户端连接到FTP服务器的21端口,发送用户名和密码登录,登录成功后要list列表或者读取数据时,客户端随机开放一个端口(1024以上),发送 PORT命令到FTP服务器,告诉服务器客户端采用主动模式并开放端口;FTP服务器收到PORT主动模式命令和端口号后,通过服务器的20端口和客户端开放的端口连接,发送数据。

(2) PASV(被动模式)

PASV是Passive的缩写,中文成为被动模式,工作原理:FTP客户端连接到FTP服务器的21端口,发送用户名和密码登录,登录成功后要list列表或者读取数据时,发送PASV命令到FTP服务器, 服务器在本地随机开放一个端口(1024以上),然后把开放的端口告诉客户端, 客户端再连接到服务器开放的端口进行数据传输。

关于主动和被动模式可参考:https://www.cnblogs.com/ajianbeyourself/p/7655464.html

和https://www.cnblogs.com/yeyublog/p/6056424.html

也就是说,服务器开放的数据端口,防火墙限制了,连不上,所以得在ftp服务器的配置里规定一个范围的端口号作为数据端口,然后再在防火墙设置这些端口可访问;

设置方法:在ftp的配置文件中增加

pasv_min_port=40001
pasv_max_port=41000
在防火墙配置中增加:
-A INPUT -p tcp --dport 40001:41000 -j ACCEPT
-A OUTPUT -p tcp --dport 40001:41000 -j ACCEPT 配置信息可参考:ttps://www.cnblogs.com/ahaii/p/5390616.html