我有一个应该连接到FTP的脚本
from ftplib import FTP
with FTP('IP') as ftp:
ftp.login(user='my user', passwd='my password')
ftp.cwd('/MY_DIR')
ftp.dir()
我有一个错误:
ConnectionRefusedError: [Errno 111] Connection refused
ftp是带有vsftpd的EC2
pasv_enable=YES
pasv_min_port=1024
pasv_max_port=1048
pasv_address=IP
pasv_addr_resolve=YES
代码适用于其他带有和不带TLS的FTP(托管在1and1,OVH ......)
我在NodeJS中试过这个脚本
const ftpClient = require('ftp-client');
const client = new ftpClient({
host: "IP",
port: 21,
user: "My user", // defaults to "anonymous"
password: "My password" // defaults to "@anonymous"
});
client.connect(() => {
client.download('/MY_DIR/file','/tmp/file', (res) => {
console.log(res)
})
});
完全正常,所以我排除了防火墙问题
我尝试过启用TLS
ssl_enable=YES
require_ssl_reuse=NO
然后 sudo service vsftpd restart
并使用
FTP_TLS
代替FTP
但是没有用?
我也尝试通过设置
来禁用被动模式pasv_enable=NO
然后
sudo service vsftpd restart
和ftp.set_pasv(False)
无效
答案 0 :(得分:3)
使用filezilla调试方法后,尽管我们在/etc/vsftpd.conf
中定义了
pasv_adress=IP
这篇文章帮助了我们:https://www.centos.org/forums/viewtopic.php?t=52408
您必须发表评论
listen_ipv6=YES
并启用
listen=YES
/etc/vsftpd.conf
中的
如果你无法访问FTP的vsftpd.conf,你也可以覆盖ftplib的类FTP
class CustomFTP(ftplib.FTP):
def makepasv(self):
if self.af == socket.AF_INET:
host, port = ftplib.parse227(self.sendcmd('PASV'))
else:
host, port = ftplib.parse229(self.sendcmd('EPSV'), self.sock.getpeername())
if '0.0.0.0' == host:
""" this ip will be unroutable, we copy Filezilla and return the host instead """
host = self.host
return host, port
如果发送'0.0.0.0'