Explorer les Livres électroniques
Catégories
Explorer les Livres audio
Catégories
Explorer les Magazines
Catégories
Explorer les Documents
Catégories
pour
Introduction
TLS, ou “transport layer security” - et son prédécesseur SSL - sont des protocoles
utilisés pour envelopper le trafic normal dans une enveloppe protégée et cryptée. Grâce
à cette technologie, les serveurs peuvent envoyer en toute sécurité des informations à
leurs clients sans que leurs messages soient interceptés ou lus par une partie
extérieure.
Dans ce guide, nous vous montrerons comment créer et utiliser un certificat SSL auto-
signé avec le serveur web Apache sur Ubuntu 20.04.
En raison de cette limitation, les certificats auto-signés ne sont pas appropriés pour un
environnement de production destiné au public. Ils sont généralement utilisés pour les
tests ou pour sécuriser des services non critiques utilisés par un seul utilisateur ou un
petit groupe d’utilisateurs qui peuvent établir la confiance dans la validité du certificat par
d’autres canaux de communication.
Pour une solution de certificat plus adaptée à la production, consultez Let’s Encrypt, une
autorité de certification gratuite. Vous pouvez apprendre comment télécharger et
configurer un certificat Let’s Encrypt dans notre tutoriel Comment sécuriser Apache avec
Let’s Encrypt sur Ubuntu 20.04.
Conditions préalables
Avant de commencer ce TP, vous aurez besoin des éléments suivants :
• Vous devrez avoir installé Apache. Vous pouvez installer Apache en
utilisant apt. Tout d’abord, mettez à jour l’index local des paquets afin de
refléter les derniers changements en amont :
Enfin, si vous avez installé un pare-feu ufw, ouvrez les ports http et https :
Une fois ces étapes terminées, assurez-vous que vous êtes connecté en tant que
non- root user et poursuivez le tutoriel.
Nous pouvons créer les fichiers de clés et de certificats SSL avec la commande openssl :
1. sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/ssl/private/apache-
selfsigned.key -out /etc/ssl/certs/apache-selfsigned.crt
2.
Après avoir entré la commande, vous serez amené à une invite où vous pourrez entrer
des informations sur votre site web. Avant d’en parler, voyons ce qui se passe dans la
commande que nous donnons :
Remplissez les invites de manière appropriée. La ligne la plus importante est celle qui
demande le Common Name (nom commun). Vous devez entrer soit le nom d’hôte que
vous utiliserez pour accéder au serveur, soit l’adresse IP publique du serveur. Il est
important que ce champ corresponde à ce que vous allez mettre dans la barre
d’adresse de votre navigateur pour accéder au site, car une mauvaise correspondance
entraînera davantage d’erreurs de sécurité.
Les deux fichiers que vous avez créés seront placés dans les sous-répertoires
appropriés sous /etc/ssl.
Ensuite, nous mettrons à jour notre configuration Apache pour utiliser le nouveau
certificat et la nouvelle clé.
Pour ce tutoriel, nous allons créer un nouveau fichier de configuration minimale. (Si vous
avez déjà configuré Apache <Virtualhost> et que vous devez juste y ajouter SSL, vous
devrez probablement copier les lignes de configuration qui commencent par SSL, et
changer le port du VirtualHost de 80 à 443. Nous nous occuperons du port 80 dans la
prochaine étape).
/etc/apache2/sites-available/your_domain_or_ip.conf
<VirtualHost *:443>
ServerName your_domain_or_ip
DocumentRoot /var/www/your_domain_or_ip
SSLEngine on
SSLCertificateFile /etc/ssl/certs/apache-selfsigned.crt
SSLCertificateKeyFile /etc/ssl/private/apache-selfsigned.key
</VirtualHost>
Veillez à mettre à jour la ligne ServerName en fonction de la manière dont vous avez
l’intention de nommer votre serveur. Il peut s’agir d’un nom d’hôte, d’un nom de domaine
complet ou d’une adresse IP. Assurez-vous que ce que vous choisissez correspond
au Common Name (nom commun) que vous avez choisi lors de l’établissement du
certificat.
Les lignes restantes indiquent un répertoire DocumentRoot à partir duquel les fichiers
seront servis, ainsi que les options SSL nécessaires pour faire pointer Apache vers
notre certificat et notre clé nouvellement créés.
Nous allons maintenant créer notre DocumentRoot et y insérer un fichier HTML à des fins
de test :
/var/www/your_domain_or_ip/index.html
<h1>it worked!</h1>
Ce n’est pas un fichier HTML complet, bien sûr, mais les navigateurs sont indulgents et
cela suffira pour vérifier notre configuration.
Output
AH00558: apache2: Could not reliably determine the server's fully qualified domain name, using
127.0.1.1. Set the 'ServerName' directive globally to suppress this message
Syntax OK
La première ligne est un message vous indiquant que la directive ServerName n’est pas
définie globalement. Si vous ne voulez plus voir ce message s’afficher, vous pouvez
définir ServerName en spécifiant le nom de domaine ou l’adresse IP de votre serveur
dans /etc/apache2/apache2.conf. Ceci est facultatif car le message ne fera pas de mal.
Si votre sortie contient Syntax OK, votre fichier de configuration ne contient aucune erreur
de syntaxe. Nous pouvons recharger Apache en toute sécurité pour que nos
modifications soient appliquées :
Chargez maintenant votre site dans un navigateur, en veillant à utiliser https:// au début.
Vous devriez voir une erreur. C’est normal pour un certificat auto-signé ! Le navigateur
vous avertit qu’il ne peut pas vérifier l’identité du serveur, car notre certificat n’est signé
par aucune de ses autorités de certification connues. Pour les tests et l’utilisation
personnelle, cela peut être très bien. Vous devriez pouvoir cliquer pour accéder à des
informations avancées ou complémentaires et choisir de poursuivre.
Une fois que vous l’aurez fait, votre navigateur chargera le message it worked! .
Nous allons ensuite ajouter une autre section VirtualHost à notre configuration pour servir
les requêtes HTTP simples et les rediriger vers HTTPS.
Ouvrez le même fichier de configuration Apache que celui que nous avons lancé lors
des étapes précédentes :
En bas, créez un autre bloc VirtualHost pour faire correspondre les demandes sur le
port 80. Utilisez la directive ServerName pour faire correspondre à nouveau votre nom de
domaine ou votre adresse IP. Ensuite, utilisez Redirect (Rediriger) pour faire
correspondre les requêtes et les envoyer au VirtualHost SSL. Veillez à inclure la barre
oblique :
/etc/apache2/sites-available/your_domain_or_ip.conf
<VirtualHost *:80>
ServerName your_domain_or_ip
Redirect / https://your_domain_or_ip/
</VirtualHost>
Enregistrez et fermez ce fichier lorsque vous avez terminé, puis testez à nouveau la
syntaxe de votre configuration, et rechargez Apache :
Vous pouvez tester la nouvelle fonctionnalité de redirection en visitant votre site avec le
simple http:// devant l’adresse. Vous devriez être redirigé automatiquement vers https://.
Conclusion
Vous avez maintenant configuré Apache pour servir des demandes cryptées en utilisant
un certificat SSL auto-signé, et pour rediriger les demandes HTTP non cryptées vers
HTTPS.
Si vous envisagez d’utiliser SSL pour un site web public, vous devriez envisager
d’acheter un nom de domaine et d’utiliser une autorité de certification largement
reconnue telle que Let’s Encrypt.