pyftpdlib 运行但似乎没有在端口上侦听其他 ftp 服务器应用程序工作

pyftpdlib runs but doesn't seem to be listening on port yet other ftp server apps work

我正在 Windows Python 中 运行 构建一个 ftp 服务器。我采用了 pyftpdlib 的基本示例,如下所示。

import os
from pyftpdlib.authorizers import DummyAuthorizer
from pyftpdlib.handlers import FTPHandler
from pyftpdlib.servers import FTPServer

def main():
    # Instantiate a dummy authorizer for managing 'virtual' users
    authorizer = DummyAuthorizer()

    # Define a new user having full r/w permissions and a read-only
    # anonymous user
    authorizer.add_user('user', '12345', "c:\temp", perm='elradfmwM')
    authorizer.add_anonymous(os.getcwd())

    # Instantiate FTP handler class
    handler = FTPHandler
    handler.authorizer = authorizer

    # Define a customized banner (string returned when client connects)
    handler.banner = "pyftpdlib based ftpd ready."

    # Specify a masquerade address and the range of ports to use for
    # passive connections.  Decomment in case you're behind a NAT.
    #handler.masquerade_address = '151.25.42.11'
    #handler.passive_ports = range(60000, 65535)

    # Instantiate FTP server class and listen on 0.0.0.0:2121
    address = ('', 21)
    server = FTPServer(address, handler)

    # set a limit for connections
    server.max_cons = 256
    server.max_cons_per_ip = 5

    # start ftp server
    server.serve_forever()

if __name__ == '__main__':
    main()

当它 runs/executes 它似乎在等待时,没有其他东西正在使用端口 21。请参阅下面的过程输出。

[I 2017-04-17 19:05:55] >>> starting FTP server on :::21, pid=43124 <<<
[I 2017-04-17 19:05:55] concurrency model: async
[I 2017-04-17 19:05:55] masquerade (NAT) address: None
[I 2017-04-17 19:05:55] passive ports: None

但是我无法从远程 windows 主机远程登录到主机上的端口 21,其中 pyftpdlib 脚本是 运行ning。我有另一个单独的独立 ftp 服务器 .exe 用于 windows 运行ning,它工作正常我可以从远程 windows 主机远程登录到主机上的端口 21 我可以'无法正确地从 pyftpdlib 到 运行,所以我知道这不是任何固件或网络问题。

我真的很困惑为什么这个模块 pyftpdlib 不起作用。

可能是因为它正在侦听 IPv6 地址。尝试改变这个:

address = ('', 21)

对此:

address = ('0.0.0.0', 21)