我正在尝试编写一个偶尔会访问Filezilla服务器的脚本以检索文件。我对Filezilla服务器和配置具有管理权限,但对系统或网络的其余部分没有管理权限,但是可以提出请求。
代码:
from ftplib import FTP_TLS
host="11.211.171.41"
ftps = FTP_TLS(host)
ftps.login()
ftps.prot_p()
ftps.dir()
#-r--r--r-- 1 ftp ftp 5636096 Aug 07 00:50 master.mdf
#-r--r--r-- 1 ftp ftp 2097152 Aug 07 00:50 mastlog.ldf
filename = "master.mdf"
with open(filename, 'wb') as f:
ftps.retrbinary('RETR {}'.format(filename), f.write)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/home/fcontreras/scripts/ftps/ftps.py", line 29, in get
ftps.retrbinary('RETR {}'.format(filename), f.write)
File "/home/fcontreras/miniconda3/envs/ftp/lib/python3.6/ftplib.py", line 442, in retrbinary
with self.transfercmd(cmd, rest) as conn:
File "/home/fcontreras/miniconda3/envs/ftp/lib/python3.6/ftplib.py", line 399, in transfercmd
return self.ntransfercmd(cmd, rest)[0]
File "/home/fcontreras/miniconda3/envs/ftp/lib/python3.6/ftplib.py", line 801, in ntransfercmd
server_hostname=self.host)
File "/home/fcontreras/miniconda3/envs/ftp/lib/python3.6/ssl.py", line 407, in wrap_socket
_context=self, _session=session)
File "/home/fcontreras/miniconda3/envs/ftp/lib/python3.6/ssl.py", line 814, in __init__
self.do_handshake()
File "/home/fcontreras/miniconda3/envs/ftp/lib/python3.6/ssl.py", line 1068, in do_handshake
self._sslobj.do_handshake()
File "/home/fcontreras/miniconda3/envs/ftp/lib/python3.6/ssl.py", line 689, in do_handshake
self._sslobj.do_handshake()
ssl.SSLEOFError: EOF occurred in violation of protocol (_ssl.c:841)
所以重点是要纠正该错误,但是我很难找出(_ssl.c:841)的含义,我不确定从哪里开始寻找。
答案 0 :(得分:0)
发现了问题,SSLEOFError令人误解,该错误是由于数据库不可读引起的。
由于权限显示为:
#-r--r--r-- 1 ftp ftp 5636096 Aug 07 00:50 master.mdf
#-r--r--r-- 1 ftp ftp 2097152 Aug 07 00:50 mastlog.ldf
创建它们的数据库引擎似乎永久将它们打开,并且Windows不允许用户或FTP服务器读取要传输的文件。
希望这将有助于减少某人的Google时间。