如何使用m2crypto在FTPS服务器上上传文件

1 投票
1 回答
3119 浏览
提问于 2025-04-16 05:19

我正在尝试使用FTPS将文件上传到我们的FTP服务器。登录很简单,没问题:

from M2Crypto import ftpslib
ftp = ftpslib.FTP_TLS()
ftp.connect(host)
ftp.login(username, password)

而且进入目录也没问题:

for dir in directory:
    ftp.cwd(dir)

但是,当我尝试获取目录内容时:

if directory_name not in ftp.nlst():
    ftp.mkd(directory_name)

我遇到了522错误:

File "/usr/lib/python2.5/ftplib.py", line 459, in nlst
  self.retrlines(cmd, files.append)
File "/usr/lib/python2.5/ftplib.py", line 407, in retrlines
  conn = self.transfercmd(cmd)
File "/usr/lib/python2.5/ftplib.py", line 356, in transfercmd
  return self.ntransfercmd(cmd, rest)[0]
File "/var/lib/python-support/python2.5/M2Crypto/ftpslib.py", line 86, in ntransfercmd
  conn, size = FTP.ntransfercmd(self, cmd, rest)
File "/usr/lib/python2.5/ftplib.py", line 327, in ntransfercmd
  resp = self.sendcmd(cmd)
File "/usr/lib/python2.5/ftplib.py", line 241, in sendcmd
  return self.getresp()
File "/usr/lib/python2.5/ftplib.py", line 216, in getresp
  raise error_perm, resp
ftplib.error_perm: 522 Data connections must be encrypted.

看起来TLS只用于握手,而不是用于传输数据。

有没有办法确保传输安全(我想使用storbinary()上传文件)使用M2Crypto?如果不行,还有其他选择吗?

1 个回答

4

解决办法是在调用 login() 后,明确请求保护传输:

ftp.prot_p()

撰写回答