- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 AWS EC2 (Ubuntu16.04) 上使用被动模式 (PASV
) 设置了 FTP 服务器,但它不起作用。但是,它可以与 EPSV 一起使用,不知道为什么。我四处搜寻但没有找到答案,有人可以帮助我吗?
<强>1。 vsftpd 配置
anonymous_enable=NO
local_enable=YES
write_enable=YES
chroot_local_user=YES
pasv_enable=YES
pasv_min_port=13000
pasv_max_port=13100
port_enable=YES
pasv_address=[public ip address of AWS EC2 instance]
allow_writeable_chroot=YES
seccomp_sandbox=NO
<强>2。 AWS EC2 防火墙
<强>3。通过FireFTP测试
使用PASV
模式,无法连接FTP服务器,日志为:
220 (vsFTPd 3.0.3)
USER sensor
331 Please specify the password.
PASS (password not shown)
230 Login successful.
CWD /
250 Directory successfully changed.
TYPE A
200 Switching to ASCII mode.
PASV
QUIT
但是,它与 EPSV
配合使用(选中 IPV6 复选框),日志如下:
220 (vsFTPd 3.0.3)
USER sensor
331 Please specify the password.
PASS (password not shown)
230 Login successful.
PWD
257 "/" is the current directory
TYPE A
200 Switching to ASCII mode.
EPSV
229 Entering Extended Passive Mode (|||13082|)
LIST
150 Here comes the directory listing.
226 Directory send OK.
<强>4。通过Python ftplib测试
from ftplib import FTP
contents = []
ftp = FTP(host=xxx, timeout=3000)
ftp.login(user=xxx, passwd=xxx)
ftp.set_debuglevel(2)
ftp.retrlines("NLST", contents.append)
ftp.quit()
日志如下:
*cmd* 'TYPE A'
*put* 'TYPE A\r\n'
*get* '200 Switching to ASCII mode.\n'
*resp* '200 Switching to ASCII mode.'
*cmd* 'PASV'
*put* 'PASV\r\n'
*get* '227 Entering Passive Mode (0,0,0,0,50,245).\n'
*resp* '227 Entering Passive Mode (0,0,0,0,50,245).'
ConnectionRefusedError: [Errno 111] Connection refused
最佳答案
对我来说,这看起来像是 vsftpd 中的一个错误。
从代码来看,它总是会发送 0,0,0,0
、若公众pasv_address
已设置,但服务器有一个(本地)IPv6 地址。
要解决此问题,请确保服务器不监听 IPv6 地址(默认行为是什么,您可以通过设置 listen_ipv6=YES
覆盖它):
listen_ipv6=NO
listen=YES
唯一的其他解决方案是删除私有(private) IPv6 地址(如果在 EC2 中可行的话)。
或者使用另一个 FTP 服务器,例如ProFTPD .
或者让 ftplib 忽略服务器返回的 IP 地址。
请参阅Cannot list FTP directory using ftplib – but FTP client works
为了证明这确实是一个错误,请检查最新 vsftpd 版本(3.0.3)的代码:
handle_pasv
在postlogin.c
:
int is_ipv6 = vsf_sysutil_sockaddr_is_ipv6(p_sess->p_local_addr);
...
if (tunable_pasv_address != 0)
{
vsf_sysutil_sockaddr_alloc_ipv4(&s_p_sockaddr);
/* Report passive address as specified in configuration */
if (vsf_sysutil_inet_aton(tunable_pasv_address, s_p_sockaddr) == 0)
{
die("invalid pasv_address");
}
}
else
{
vsf_sysutil_sockaddr_clone(&s_p_sockaddr, p_sess->p_local_addr);
}
str_alloc_text(&s_pasv_res_str, "Entering Passive Mode (");
if (!is_ipv6)
{
str_append_text(&s_pasv_res_str, vsf_sysutil_inet_ntop(s_p_sockaddr));
}
else
{
const void* p_v4addr = vsf_sysutil_sockaddr_ipv6_v4(s_p_sockaddr);
if (p_v4addr)
{
str_append_text(&s_pasv_res_str, vsf_sysutil_inet_ntoa(p_v4addr));
}
else
{
str_append_text(&s_pasv_res_str, "0,0,0,0");
}
}
其中vsf_sysutil_sockaddr_ipv6_v4
如果s_p_sockaddr
则返回0当 pasv_address
时,它不是 IPv6,但它从来都不是。已设置。
sysutil.c
:
const void*
vsf_sysutil_sockaddr_ipv6_v4(const struct vsf_sysutil_sockaddr* p_addr)
{
static unsigned char pattern[12] =
{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xFF, 0xFF };
const unsigned char* p_addr_start;
if (p_addr->u.u_sockaddr.sa_family != AF_INET6)
{
return 0;
}
if (vsf_sysutil_memcmp(pattern, &p_addr->u.u_sockaddr_in6.sin6_addr, 12))
{
return 0;
}
p_addr_start = (const unsigned char*)&p_addr->u.u_sockaddr_in6.sin6_addr;
return &p_addr_start[12];
}
恕我直言,代码错误。当 IP 地址从 p_sess->p_local_addr
“自动检测”时,它起作用(并且有意义)。 ,但是失败,当 pasv_address
地址已使用。
考虑向 vsftpd 的作者报告此问题。
<小时/>保留 PASV
的原始解释与 EPSV
:
只是为了解释 PASV
之间的区别和 EPSV
:PASV
在响应中返回 IP 地址。该信息 99.9% 是冗余的。当服务器不知道其外部 IP 地址时,它通常会导致问题。
EPSV
晚于 PASV
推出,当很明显响应中的 IP 地址存在问题时。所以用EPSV
,仅包含端口号。并且客户端隐式连接到FTP服务器IP地址。
如果服务器确实返回0,0,0,0
回应PASV
命令,很清楚为什么客户端无法连接到服务器,当 PASV
已使用。
关于amazon-ec2 - vsftpd 返回 0,0,0,0 以响应 PASV,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41046707/
我决定在C#中滚动我自己的FTP套接字客户端,以便获得更多控制权,但主要是为了学习经验。但是我无法确定发出RETR命令后需要读取多少文件数据。我能够建立初始的FTP通信连接,然后通过发出PASV命令和
我正在编写一个 FTP 服务器,但我不理解 PASV 命令,任何服务器都会发送这样的响应: 227 Entering Passive Mode (213,229,112,130,216,4) 括号里的
尽量简短 我使用 c# .net 3.5 编写了自定义 FTP 实现。系统使用 TcpClient(主动模式下的 TcpListener)来管理连接。在单个实例中出现奇怪的行为,我想询问可能的原因。
有没有人成功地使用 .Net FTPWebRequest 类从 NAT 后面 ftps 到远程服务器?我的代码如下: Dim URI = "ftp://" & sRemoteDir & "/"
System.Net.WebException: The server returned an address in response to the PASV command that is diff
在我的 TCP 服务器上,我希望有: 非阻塞被动套接字具有非阻塞accept(); 接受连接后,我想执行一些身份验证,例如验证客户端提供的 ID 和密码。所以我有明确定义的协议(protocol),我
我已经在 Ubuntu 12.04 LTS 中设置了 FTP 服务器。 现在,当我尝试通过命令行 ftp.exe 从 Windows 7 连接到 FTP 服务器时,我已成功连接,但无法获取目录列表。我
当我使用 PHP 的 cURL 扩展(使用 curl_setopt 命令)时,我找不到像 --ftp-skip-pasv-ip 这样的选项。 --ftp-skip-pasv-ip 在 PHP cURL
我在 AWS EC2 (Ubuntu16.04) 上使用被动模式 (PASV) 设置了 FTP 服务器,但它不起作用。但是,它可以与 EPSV 一起使用,不知道为什么。我四处搜寻但没有找到答案,有人可
请先看我的窗体代码: using System; using System.Collections.Generic; using System.Comp
我正在尝试编写 FTP 客户端程序,但似乎无法连接到被动端口。我想最终列出目录并下载文件,但我也不知道该怎么做。 这是我的程序打印出来的内容。 PASV 227 Entering Passive Mo
我使用 .NET 4.0 创建了一个自定义 FTP 服务器。我在同一台 Windows 7 机器上同时运行客户端和服务器,并且我的防火墙完全被禁用。我可以使用 FileZilla 和 FtpUse 连
我是一名优秀的程序员,十分优秀!