要在Ubuntu上配置FTP服务器以支持SSL/TLS,您需要执行以下步骤:
安装vsftpd: 在终端中运行以下命令以安装vsftpd(非常安全的FTP守护程序):
sudo apt-get update
sudo apt-get install vsftpd
生成SSL证书和密钥: 使用OpenSSL生成自签名SSL证书和私钥。在终端中运行以下命令:
sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/ssl/private/vsftpd.pem -out /etc/ssl/private/vsftpd.pem
按照提示输入相关信息。这将在指定的目录中生成一个名为vsftpd.pem的文件,其中包含SSL证书和私钥。
配置vsftpd以使用SSL/TLS: 使用文本编辑器打开/etc/vsftpd.conf文件:
sudo nano /etc/vsftpd.conf
在文件中找到以下行(如果找不到,请添加它们):
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
rsa_cert_file=/etc/ssl/private/vsftpd.pem
rsa_private_key_file=/etc/ssl/private/vsftpd.pem
保存并关闭文件。
重启vsftpd服务: 在终端中运行以下命令以重启vsftpd服务,使更改生效:
sudo systemctl restart vsftpd
配置防火墙: 如果您启用了UFW防火墙,请运行以下命令以允许FTP连接:
sudo ufw allow 21/tcp
sudo ufw allow 990/tcp
sudo ufw allow 40000:50000/tcp
现在,您的Ubuntu FTP服务器已配置为支持SSL/TLS。客户端现在可以使用FTPS(FTP over SSL/TLS)连接到服务器,通常使用端口990进行隐式连接,或使用端口21进行显式连接。请注意,由于我们使用了自签名证书,某些客户端可能会警告您证书不受信任。在这种情况下,您可以选择接受证书或将服务器的证书导入到客户端的受信任证书颁发机构列表中。