如何使用SSL / TLS保护vsFTPd

非常安全的FTP守护程序,或简称为vsFTPd,是一款轻量级的软件,具有强大的自定义功能。在本教程中,我们将使用我们自己的自签名SSL / TLS证书来保护Debian系统上已经存在的安装。尽管它是为Debian编写的,但它应该可以在大多数Linux发行版中使用,例如Ubuntu和CentOS。


vsFTPd的安装

在新的Linux VPS上,您需要首先安装vsFTPd。尽管您会在本教程中找到安装vsFTPd的基本步骤,但我还是建议您阅读以下两个更详细的教程:在Debian / Ubuntu上安装vsFTPd在CentOS上安装vsFTPd。有关安装的所有步骤都在此处进行了更详细的说明。

在Debian / Ubuntu上安装:

apt-get install vsftpd

在CentOS上安装:

yum install epel-release
yum install vsftpd

配置在您喜欢的文本编辑器中 打开配置文件:/etc/vsftpd.conf,在本教程中,我们使用nano

nano /etc/vsftpd.conf

将以下行粘贴到配置中:

anonymous_enable=NO
local_enable=YES
write_enable=YES
chroot_local_user=YES

通过重新启动vsFTPd守护程序来完成:

/etc/init.d/vsftpd restart

现在,您应该能够以任何本地用户的身份通过FTP登录,现在让我们继续并保护此软件。


生成自签名证书

自签名证书通常用于公钥协议中,您现在将使用它openssl来生成公钥和相应的私钥。首先,我们需要创建一个目录来存储这两个密钥文件,最好是普通用户无法访问的安全位置。

mkdir -p /etc/vsftpd/ssl

现在到证书的实际生成,我们将把两个密钥存储在同一文件中(/etc/vsftpd/ssl/vsftpd.pem):

openssl req -x509 -nodes -days 365 -newkey rsa:4096 -keyout /etc/vsftpd/ssl/vsftpd.pem -out /etc/vsftpd/ssl/vsftpd.pem

执行命令后,系统将询问您一些问题,例如国家代码,州,城市,组织名称等。请使用您自己的或组织的信息。现在,最重要的行是通用名称,该名称必须与您的VPS的IP地址匹配,或者指向它的域名。

该证书有效期为365天(〜1年),它将使用RSA密钥协议协议,密钥长度为4096位,并且包含这两个密钥的文件将存储在我们刚刚创建的新目录中。有关密钥长度及其与安全性的关系的更多详细信息,请参阅:Encryption II recomendations


在vsFTPd中安装新证书

要开始使用我们的新证书并提供加密,我们需要再次打开配置文件:

nano /etc/vsftpd.conf

我们需要将路径添加到新证书和密钥文件。由于它们存储在同一文件中,因此在配置内部也应该相同。

rsa_cert_file=/etc/vsftpd/ssl/vsftpd.pem
rsa_private_key_file=/etc/vsftpd/ssl/vsftpd.pem

我们必须添加以下行以确保将启用SSL:

ssl_enable=YES

(可选)我们可以阻止匿名用户使用SSL,因为公共FTP服务器上不需要加密。

allow_anon_ssl=NO

接下来,我们需要指定何时使用SSL / TLS,这将为数据传输和登录凭据启用加密

force_local_data_ssl=YES
force_local_logins_ssl=YES

我们可能还会指定要使用的版本和协议。TLS通常比SSL更安全,因此我们可以允许TLS,同时阻止更旧的SSL版本。

ssl_tlsv1=YES
ssl_sslv2=NO
ssl_sslv3=NO

要求SSL重用,并且使用高密码也将有助于提高安全性。从vsFTPd的手册页中:

require_ssl_reuse 如果设置为yes,则所有SSL数据连接都必须具有SSL会话重用性(这证明它们知道与控制通道相同的主密钥)。尽管这是一个安全的默认设置,但它可能会破坏许多FTP客户端,因此您可能要禁用它。有关后果的讨论,请参见http://scarybeastsecurity.blogspot.com/2009/02/vsftpd-210-released.html(在v2.1.0中添加)。

ssl_ciphers 此选项可用于选择vsftpd允许使用哪些SSL密码进行加密的SSL连接。有关更多详细信息,请参见密码手册页。请注意,限制密码可能是有用的安全预防措施,因为它可以防止恶意远程方强制使用他们发现问题的密码。

require_ssl_reuse=YES
ssl_ciphers=HIGH

通过重新启动vsftpd守护程序完成

/etc/init.d/vsftpd restart

确认安装

就是这样,您现在应该可以连接到服务器并确认一切正常。如果使用FileZilla,则在连接时将打开一个对话框,其中包含组织信息(或先前生成证书时输入的信息)。然后,输出应类似于以下内容:

Status: Connection established, waiting for welcome message...
Status: Initializing TLS...
Status: Verifying certificate...
Status: TLS connection established.

要了解有关vsFTPd的更多信息,请查看其手册页:

man vsftpd


Leave a Comment

如何在CentOS 7上安装Oxwall

如何在CentOS 7上安装Oxwall

Oxwall是一个开源社交网络软件平台,可用于免费构建自定义社交网站(SNS)。在这篇文章中,

如何在CentOS 7上设置vsFTPd

如何在CentOS 7上设置vsFTPd

FTP是用于通过Internet传输文件的有用协议,本指南将向您展示如何设置vsFTPd(非常安全的文件传输协议守护程序)o

使用Nethogs监视网络带宽使用情况

使用Nethogs监视网络带宽使用情况

在本教程中,我们将介绍在CentOS 6x x64上安装和使用nethogs的过程。nethogs是一种网络监视工具,它允许Networ

如何在CentOS 7上安装BoltWire CMS

如何在CentOS 7上安装BoltWire CMS

使用其他系统?简介BoltWire是一个用PHP编写的免费,轻量级的内容管理系统。与大多数其他内容管理人员相比

在CentOS 6上设置SA-MP San Andreas多人服务器

在CentOS 6上设置SA-MP San Andreas多人服务器

欢迎来到另一个Vultr教程。在这里,您将学习如何安装和运行SAMP服务器。本指南是为CentOS 6编写的。先决条件

使用Etckeeper进行/ etc的版本控制

使用Etckeeper进行/ etc的版本控制

简介/ etc /目录在Linux系统运行中起着至关重要的作用。其原因是因为几乎每个系统配置

如何在CentOS 7上安装Microweber

如何在CentOS 7上安装Microweber

使用其他系统?Microweber是一个开放源代码的拖放式CMS和在线商店。Microweber源代码托管在GitHub上。本指南将向您展示

如何在CentOS 7上安装SonarQube

如何在CentOS 7上安装SonarQube

使用其他系统?SonarQube是用于质量系统开发的开源工具。它是用Java编写的,并且支持多个数据库。它提供

如何在CentOS 7上使用Mosh进行远程服务器管理

如何在CentOS 7上使用Mosh进行远程服务器管理

使用其他系统?Mosh是Mobile Shell的缩写,是一种新兴的远程终端应用程序,旨在提供更好的连接和使用

如何在CentOS 7上安装MoinMoin

如何在CentOS 7上安装MoinMoin

MoinMoin是一个使用Python编写的基于文件系统的开源Wiki引擎。如今,MoinMoin已广泛用于开源社区。许多供应商

在CentOS 7上安装H2O Web服务器

在CentOS 7上安装H2O Web服务器

H2O是新一代HTTP服务器,它对所有当前使用的Web服务器都具有出色的,功能齐全的HTTP / 2实现。使用H2O作为您的Web服务器

如何在Debian,CentOS和FreeBSD上使用Sudo

如何在Debian,CentOS和FreeBSD上使用Sudo

在Linux和Unix系统管理员中,使用sudo用户访问服务器并在root级执行命令是一种非常普遍的做法。使用泡沫

如何在Ubuntu 16.10上安装Countly Analytics

如何在Ubuntu 16.10上安装Countly Analytics

使用其他系统?Countly是一个开源Web /移动分析和营销平台。它具有许多用于从Web收集数据的功能

如何在CentOS 7上安装MODX CMS和Nginx

如何在CentOS 7上安装MODX CMS和Nginx

MODX是一个用PHP编写的免费开放源内容管理系统。它使用MySQL或MariaDB来存储其数据库。MODX专为满足以下条件的企业而设计:

如何在CentOS 7 LAMP VPS上安装Lychee 3.1相册

如何在CentOS 7 LAMP VPS上安装Lychee 3.1相册

使用其他系统?Lychee 3.1相册是一种简单,灵活,免费和开源的照片管理工具,可在VPS服务器上运行。安装

如何在CentOS 7上安装ERPNext开源ERP

如何在CentOS 7上安装ERPNext开源ERP

使用其他系统?ERP或企业资源计划是用于管理核心业务流程的企业应用程序套件。ERPNext是免费的

如何在CentOS 7 LAMP VPS上安装Paste 2.1

如何在CentOS 7 LAMP VPS上安装Paste 2.1

使用其他系统?Paste 2.1是一个简单,灵活,免费和开源的pastebin应用程序,用于存储代码,文本等。最初是

如何在CentOS 7上安装Seafile Server

如何在CentOS 7上安装Seafile Server

使用其他系统?Seafile(社区版本)是一个免费和开源的文件同步和共享解决方案,类似于ownCloud。机智

如何在CentOS 7上安装Kolab组件

如何在CentOS 7上安装Kolab组件

使用其他系统?Kolab Groupware是一个免费的基于Web的开源组件软件。它的功能包括电子邮件通信,事件

如何在CentOS 7 LAMP VPS上安装Omeka Classic 2.4 CMS

如何在CentOS 7 LAMP VPS上安装Omeka Classic 2.4 CMS

使用其他系统?Omeka Classic 2.4 CMS是一个免费的开源数字发布平台和用于共享数字内容的内容管理系统(CMS)

AI 能否應對越來越多的勒索軟件攻擊?

AI 能否應對越來越多的勒索軟件攻擊?

勒索軟件攻擊呈上升趨勢,但人工智能能否幫助應對最新的計算機病毒?AI 是答案嗎?在這裡閱讀知道是 AI 布恩還是禍根

ReactOS:這是 Windows 的未來嗎?

ReactOS:這是 Windows 的未來嗎?

ReactOS,一個開源和免費的操作系統,這裡有最新版本。它能否滿足現代 Windows 用戶的需求並打倒微軟?讓我們更多地了解這種老式但更新的操作系統體驗。

通過 WhatsApp 桌面應用程序 24*7 保持聯繫

通過 WhatsApp 桌面應用程序 24*7 保持聯繫

Whatsapp 終於為 Mac 和 Windows 用戶推出了桌面應用程序。現在您可以輕鬆地從 Windows 或 Mac 訪問 Whatsapp。適用於 Windows 8+ 和 Mac OS 10.9+

人工智能如何將流程自動化提升到新的水平?

人工智能如何將流程自動化提升到新的水平?

閱讀本文以了解人工智能如何在小型公司中變得流行,以及它如何增加使它們成長並為競爭對手提供優勢的可能性。

macOS Catalina 10.15.4 補充更新引發的問題多於解決

macOS Catalina 10.15.4 補充更新引發的問題多於解決

最近,Apple 發布了 macOS Catalina 10.15.4 補充更新以修復問題,但似乎該更新引起了更多問題,導致 mac 機器變磚。閱讀這篇文章以了解更多信息

大數據的13個商業數據提取工具

大數據的13個商業數據提取工具

大數據的13個商業數據提取工具

什麼是日誌文件系統,它是如何工作的?

什麼是日誌文件系統,它是如何工作的?

我們的計算機以稱為日誌文件系統的有組織的方式存儲所有數據。這是一種有效的方法,可以讓計算機在您點擊搜索時立即搜索和顯示文件。 https://wethegeek.com/?p=94116&preview=true

技術奇點:人類文明的遙遠未來?

技術奇點:人類文明的遙遠未來?

隨著科學的快速發展,接管了我們的大量工作,我們陷入無法解釋的奇點的風險也在增加。閱讀,奇點對我們意味著什麼。

洞察 26 種大數據分析技術:第 1 部分

洞察 26 種大數據分析技術:第 1 部分

洞察 26 種大數據分析技術:第 1 部分

2021 年人工智能對醫療保健的影響

2021 年人工智能對醫療保健的影響

過去幾十年,醫療保健領域的人工智能取得了巨大飛躍。因此,醫療保健中人工智能的未來仍在日益增長。