Hur man säkrar vsFTPd med SSL/TLS

Mycket säker FTP-demon, eller helt enkelt vsFTPd, är en lätt mjukvara med stor förmåga att anpassa. I den här handledningen kommer vi att säkra en redan existerande installation på ett Debiansystem med vårt eget självsignerade SSL/TLS-certifikat. Trots att den är skriven för Debian borde den fungera på de flesta Linux-distributioner som Ubuntu och CentOS till exempel.


Installation av vsFTPd

På en ny Linux VPS måste du först installera vsFTPd. Även om du hittar de grundläggande stegen för att installera vsFTPd i den här handledningen rekommenderar jag att du också läser dessa två mer detaljerade handledningar: Installera vsFTPd på Debian/Ubuntu och Installera vsFTPd på CentOS . Alla steg angående installationen förklaras mer noggrant där.

Installation på Debian/Ubuntu:

apt-get install vsftpd

Installation på CentOS:

yum install epel-release
yum install vsftpd

Konfiguration Öppna konfigurationsfilen: /etc/vsftpd.conf i din favorittextredigerare, i den här handledningen använder vi nano.

nano /etc/vsftpd.conf

Klistra in följande rader i konfigurationen:

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

Avsluta genom att starta om din vsFTPd-demon:

/etc/init.d/vsftpd restart

Du bör nu kunna logga in som vilken lokal användare som helst via FTP, låt oss nu gå vidare och säkra denna programvara.


Skapa ett självsignerat certifikat

Ett självsignerat certifikat används vanligtvis i ett avtalsprotokoll för offentlig nyckel, som du nu kommer att använda för opensslatt generera en offentlig nyckel och en motsvarande privat nyckel. Först och främst måste vi skapa en katalog för att lagra dessa två nyckelfiler, helst på en säker plats som normala användare inte kan komma åt.

mkdir -p /etc/vsftpd/ssl

Nu till den faktiska genereringen av certifikatet kommer vi att lagra båda nycklarna i samma fil ( /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

Efter att ha utfört kommandot kommer du att ställas några frågor såsom landskod, stat, stad, organisationsnamn etc. använd din egen eller din organisations information. Nu är den viktigaste raden Common name som måste matcha IP-adressen för din VPS, alternativt ett domännamn som pekar på det.

Detta certifikat kommer att vara giltigt i 365 dagar (~1 år), det kommer att använda RSA-nyckelavtalsprotokollet med en nyckellängd på 4096 bitar, och filen som innehåller båda nycklarna kommer att lagras i den nya katalogen vi just skapade. För mer information om nyckellängd och dess relation till säkerhet, se detta: Encryption II-rekommendationer .


Installera det nya certifikatet i vsFTPd

För att börja använda vårt nya certifikat och därmed tillhandahålla kryptering måste vi öppna upp konfigurationsfilen igen:

nano /etc/vsftpd.conf

Vi måste lägga till sökvägarna till våra nya certifikat och nyckelfiler. Eftersom de är lagrade i samma fil bör det vara samma i konfigurationen också.

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

Vi måste lägga till den här raden för att säkerställa att SSL kommer att vara aktiverat:

ssl_enable=YES

Valfritt kan vi blockera anonyma användare från att använda SSL, eftersom kryptering inte behövs på en offentlig FTP-server.

allow_anon_ssl=NO

Därefter måste vi ange när vi ska använda SSL/TLS, detta kommer att möjliggöra kryptering både för dataöverföring och inloggningsuppgifter

force_local_data_ssl=YES
force_local_logins_ssl=YES

Vi kan också ange vilka versioner och protokoll som ska användas. TLS är generellt sett säkrare än SSL och därför kan vi tillåta TLS och samtidigt blockera äldre versioner av SSL.

ssl_tlsv1=YES
ssl_sslv2=NO
ssl_sslv3=NO

Kräv SSL-återanvändning och användning av höga chiffer hjälper också till att förbättra säkerheten. Från vsFTPds man-sidor:

require_ssl_reuse If set to yes, all SSL data connections are required to exhibit SSL session reuse (which proves that they know the same master secret as the control channel). Although this is a secure default, it may break many FTP clients, so you may want to disable it. For a discussion of the consequences, see http://scarybeastsecurity.blogspot.com/2009/02/vsftpd-210-released.html (Added in v2.1.0).

ssl_ciphers This option can be used to select which SSL ciphers vsftpd will allow for encrypted SSL connections. See the ciphers man page for further details. Note that restricting ciphers can be a useful security precaution as it prevents malicious remote parties forcing a cipher which they have found problems with.

require_ssl_reuse=YES
ssl_ciphers=HIGH

Avsluta genom att starta om vsftpddemonen

/etc/init.d/vsftpd restart

Bekräfta installationen

Och det är det, du bör nu kunna ansluta till din server och bekräfta att allt fungerar. Om du använder FileZilla bör en dialogruta som innehåller din organisationsinformation (eller vad du angav när du genererade certifikatet tidigare) öppnas vid anslutning. Utdata ska då se ut så här:

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

För att lära dig mer om vsFTPd, kolla in dess manualsidor:

man vsftpd

Lämna en kommentar

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Artificiell intelligens är inte i framtiden, det är här i nuet I den här bloggen Läs hur Artificiell intelligens-applikationer har påverkat olika sektorer.

DDOS-attacker: En kort översikt

DDOS-attacker: En kort översikt

Är du också ett offer för DDOS-attacker och förvirrad över de förebyggande metoderna? Läs den här artikeln för att lösa dina frågor.

Har du någonsin undrat hur hackare tjänar pengar?

Har du någonsin undrat hur hackare tjänar pengar?

Du kanske har hört att hackare tjänar mycket pengar, men har du någonsin undrat hur de tjänar den typen av pengar? låt oss diskutera.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Vill du se revolutionerande uppfinningar av Google och hur dessa uppfinningar förändrade livet för varje människa idag? Läs sedan till bloggen för att se uppfinningar av Google.

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Konceptet med att självkörande bilar ska ut på vägarna med hjälp av artificiell intelligens är en dröm vi har ett tag nu. Men trots flera löften finns de ingenstans att se. Läs den här bloggen för att lära dig mer...

Technological Singularity: A Distant Future of Human Civilization?

Technological Singularity: A Distant Future of Human Civilization?

När vetenskapen utvecklas i snabb takt och tar över en hel del av våra ansträngningar, ökar också riskerna för att utsätta oss för en oförklarlig singularitet. Läs, vad singularitet kan betyda för oss.

Funktioner för Big Data Reference Architecture Layers

Funktioner för Big Data Reference Architecture Layers

Läs bloggen för att känna till olika lager i Big Data Architecture och deras funktionaliteter på enklaste sätt.

Utveckling av datalagring – Infographic

Utveckling av datalagring – Infographic

Lagringsmetoderna för data har utvecklats kan vara sedan födelsen av data. Den här bloggen tar upp utvecklingen av datalagring på basis av en infografik.

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

I denna digitala värld har smarta hemenheter blivit en avgörande del av livet. Här är några fantastiska fördelar med smarta hemenheter om hur de gör vårt liv värt att leva och enklare.

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

Nyligen släppte Apple macOS Catalina 10.15.4, en tilläggsuppdatering för att åtgärda problem, men det verkar som om uppdateringen orsakar fler problem som leder till att mac-datorer blir murade. Läs den här artikeln för att lära dig mer