我在上传文件到FTP服务器时遇到问题,出现错误:
[WinError 10049]请求的地址在其上下文中无效。
我的vsftpd.conf
listen=NO
listen_ipv6=YES
anonymous_enable=NO
write_enable=YES
dirmessage_enable=YES
use_localtime=YES
xferlog_enable=YES
connect_from_port_20=YES
chroot_local_user=YES
allow_writeable_chroot=YES
user_sub_token=$USER
local_root=/home/$USER/ftp
secure_chroot_dir=/var/run/vsftpd/empty
pam_service_name=vsftpd
pasv_min_port=40000
pasv_max_port=50000
pasv_address=0.0.0.0
userlist_enable=NO
userlist_file=/etc/vsftpd.userlist
userlist_deny=NO
rsa_cert_file=/etc/ssl/private/vsftpd.pem
rsa_private_key_file=/etc/ssl/private/vsftpd.pem
ssl_enable=YES
allow_anon_ssl=NO
force_local_data_ssl=YES
force_local_logins_ssl=YES
ssl_tlsv1=YES
ssl_sslv2=NO
ssl_sslv3=NO
require_ssl_reuse=NO
ssl_ciphers=HIGH
我的代码
def connect_ftp():
ftp = FTP_TLS(timeout=20)
ftp.connect('my_server', 21)
ftp.auth()
ftp.prot_p()
ftp.login(user= 'pnhuong', passwd='76210119')
ftp.set_pasv(True)
ftp.cwd("/files")
return ftp
def upload_file(ftp_connection, upload_file_path):
try:
upload_file1 = open(os.path.join(upload_file_path), 'r')
print('Uploading ' + upload_file_path + "...")
ftp_connection.storbinary('STOR ' + upload_file_path, upload_file1)
ftp_connection.quit()
ftp_connection.close()
upload_file.close()
print('Upload finished.')
except Exception as e:
print("Error uploading file: " + str(e))
我试着用FileZilla上传图片,结果成功了。请帮我纠正这个错误。
错误源自:
ftp_connection.storbinary('STOR ' + upload_file_path, upload_file1)
您的FTP服务器配置错误。pasv_address
指令必须设置为FTP服务器的地址。0.0.0.0
绝对无效。
pasv_address=0.0.0.0
虽然FileZilla可以启发式地解决这个问题,但许多其他FTP客户端和库将(理所当然地(失败。我相信你会在FileZilla日志文件中找到这个:
命令:PASV
响应:227进入被动模式(0,0,0,0,X,Y(
状态:服务器发送了地址不可更改的被动回复。使用服务器地址。
不过请注意,如果服务器有IPv6地址,vsftpd会有一个错误。因此,您也可以检查以下内容:
vsftpd返回0,0,0,0以响应PASV