我试图连接到一个FTPS服务器,它需要使用.pfx证书进行匿名登录。
我已经收到了关于如何通过gui应用程序SmartFTP访问它的指导,这样我就知道我没有防火墙问题等等。但是,对于这个工作流来说,通过python访问它是理想的。以下是我得到的设置:
Protocol: FTPS (Explicit)
Host: xxx.xxx.xxx.xxx
Port: 21
login type: Anonymous
Client Certificate: Enabled (providing a .pfx file)
Send FEAT: Send before and after login我在使用.pfx证书的完整示例中选择最适合这个功能的python模块时遇到了问题。目前,我只尝试使用以下代码的标准FTP模块。有人有一个有用的例子吗?
from ftplib import FTP_TLS
ftps = FTP_TLS(host='xxx.xxx.xxx.xxx',
keyfile=r"/path/to.pfx"
)
ftps.login()
ftps.prot_p()
ftps.retrlines('LIST')
ftps.quit()使用上面的代码我得到:
ValueError: certfile must be specified客户端版本: Ubuntu == 14.04,Python3.6.2
更新
认为我对下面的代码有一点了解,但是得到了一个新的错误:
from ftplib import FTP_TLS
import tempfile
import OpenSSL.crypto
def pfx_to_pem(pfx_path, pfx_password):
""" Decrypts the .pfx file to be used with requests. """
with tempfile.NamedTemporaryFile(suffix='.pem') as t_pem:
f_pem = open(t_pem.name, 'wb')
pfx = open(pfx_path, 'rb').read()
p12 = OpenSSL.crypto.load_pkcs12(pfx, pfx_password)
f_pem.write(OpenSSL.crypto.dump_privatekey(OpenSSL.crypto.FILETYPE_PEM, p12.get_privatekey()))
f_pem.write(OpenSSL.crypto.dump_certificate(OpenSSL.crypto.FILETYPE_PEM, p12.get_certificate()))
ca = p12.get_ca_certificates()
if ca is not None:
for cert in ca:
f_pem.write(OpenSSL.crypto.dump_certificate(OpenSSL.crypto.FILETYPE_PEM, cert))
f_pem.close()
yield t_pem.name
pfx = pfx_to_pem(r"/path/to.pfx", 'password')
ftps = FTP_TLS(host='xxx.xxx.xxx.xxx',
context=pfx
)
ftps.login()
ftps.prot_p()
# ftps.prot_c()
print(ftps.retrlines('LIST'))
ftps.quit()错误: ftplib.error_perm: 534服务器上的本地策略不允许TLS安全连接。
有什么想法吗?
干杯
发布于 2017-09-29 14:33:14
听起来你想做SFTP。SSL上的FTP与SFTP不一样。据我所知,SFTP (与SSH相关)在标准库中是不可能的。
有关Python:SFTP in Python? (platform independent)中的SFTP的更多信息,请参见以下内容
https://stackoverflow.com/questions/46490614
复制相似问题