Maison >Opération et maintenance >Nginx >Optimisation du protocole Nginx SSL/TLS et pratiques de sécurité
Nginx est un serveur Web et un serveur proxy inverse hautes performances apprécié pour son efficacité et sa stabilité. Dans les applications Internet actuelles, le protocole SSL/TLS est devenu un moyen essentiel pour assurer la sécurité de la transmission des données. Cet article présentera comment Nginx optimise le protocole SSL/TLS et explorera comment mettre en œuvre les pratiques de sécurité SSL/TLS.
1. Optimisation du protocole SSL/TLS
Le protocole SSL/TLS est un protocole utilisé pour assurer la sécurité de la transmission réseau. Dans les applications Web, les implémentations SSL/TLS couramment utilisées incluent OpenSSL, GnuTLS et NSS. Lors de l'utilisation de Nginx, la manière d'optimiser les performances de SSL/TLS est très importante.
Le protocole TLS est une version améliorée du protocole SSL. Il est non seulement plus sécurisé, mais aussi plus rapide. Dans Nginx, vous pouvez spécifier la version du protocole SSL/TLS en définissant le paramètre ssl_protocols. Il est recommandé d'utiliser TLS v1.2 ou supérieur, avec les anciennes versions de SSL v3 désactivées, pour empêcher les attaques POODLE contre SSL v3.
Ce qui suit est un exemple de configuration :
ssl_protocols TLSv1.2 TLSv1.3;
ssl_prefer_server_ciphers on;
Choisissez un algorithme de cryptage plus sécurisé pour améliorer la sécurité du SSL/TLS protocole. Dans Nginx, vous pouvez choisir l'algorithme de chiffrement en définissant le paramètre ssl_ciphers. Vous pouvez même personnaliser la chaîne de l'algorithme de cryptage et choisir une méthode de cryptage plus sécurisée.
re est un exemple de configuration:
ssl_ciphers ecdhe-ecdsa-aes256-gcm-sha384: ecdhe-rsa-aes256-gcm-sha384: ecdhe-ecdsa-chacha20-poly1305: ecdhe-rsa-chacha20-poly1305: ecdhe-ecdsa
ssl_prefer_server_ciphers on ;
Le cache de session peut réduire le nombre de poignées de main SSL/TLS et améliorer l'efficacité de la poignée de main. Dans Nginx, la mise en cache de session peut être activée en définissant le paramètre ssl_session_cache. Dans le même temps, vous pouvez définir le paramètre ssl_session_timeout pour spécifier le délai d'expiration du cache de session afin d'éviter que les sessions expirées ne gaspillent de la mémoire.
Voici un exemple de configuration :
ssl_session_cache shared:SSL:10m;
ssl_session_timeout 10m;
L'activation de l'agrafage OCSP peut renforcer la sécurité de SSL/TLS. OCSP Stapling est un mécanisme par lequel un serveur Web peut fournir des informations sur l'état du certificat signées par une autorité de certification (CA) lors de la négociation SSL/TLS. Cela élimine le besoin pour les clients de contacter le serveur OCSP pour obtenir l'état du certificat mis à jour, améliorant ainsi la sécurité et les performances.
Dans Nginx, vous pouvez activer l'agrafage OCSP en définissant le paramètre ssl_stapling. Dans le même temps, vous pouvez définir le paramètre ssl_stapling_verify pour spécifier le niveau de vérification des réponses OCSP.
Ce qui suit est un exemple de configuration :
ssl_stapling on;
ssl_stapling_verify on;
2. Pratiques de sécurité du protocole SSL/TLS
Le protocole SSL/TLS lui-même est hautement sécurisé. Mais si les serveurs et clients Nginx n’utilisent pas correctement le protocole SSL/TLS, ils peuvent être vulnérables aux attaques et aux fuites de données. Ainsi, lorsque vous utilisez le protocole SSL/TLS, vous devez faire attention à certaines pratiques de sécurité.
Mettez régulièrement à jour les correctifs du système d'exploitation et des logiciels, et utilisez les dernières versions TLS pour réduire l'exploitation des vulnérabilités du protocole SSL/TLS. Sinon, les attaquants pourraient exploiter les vulnérabilités pour mener des attaques malveillantes sur le serveur.
Activez HTTP Strict Transport Security (HSTS) pour garantir que lorsque les clients accèdent à des applications Web à partir du même nom de domaine, ils utilisent toujours des connexions cryptées HTTPS. Cela réduit les attaques MiTM (attaques de l'homme du milieu) et augmente le niveau de protection des utilisateurs.
Dans Nginx, HSTS peut être configuré en ajoutant le code suivant :
add_header Strict-Transport-Security "max-age=63072000; includeSubDomains; preload";
Cela activera HSTS et le définira sur 2 ans d'âge maximum, et comprend des sous-domaines.
Si vous utilisez des connexions cryptées HTTPS dans le proxy frontal, HSTS peut empêcher les attaques du schéma de détails de connexion (steal-login-details-scheme). Un système d'informations de connexion est une attaque qui vole les informations de connexion des utilisateurs en mettant sur liste blanche ou en ajoutant des sous-domaines inutiles pour inciter les utilisateurs à cliquer sur des liens et à utiliser HTTP au lieu de HTTPS.
Lorsque vous utilisez Nginx, vous devez utiliser une signature de certificat qui a été vérifiée et authentifiée par des protocoles de sécurité, sinon les attaquants pourraient l'utiliser pour voler des données. Évitez d'utiliser des algorithmes de signature associés à des protocoles obsolètes tels que MD5.
L'expansion du protocole SSL/TLS peut vous aider à obtenir un serveur Nginx plus efficace et plus sécurisé. En utilisant un serveur Nginx prenant en charge le protocole SSL/TLS, vous pouvez améliorer considérablement la sécurité et les performances de vos applications Web. Avant d'utiliser SSL/TLS, assurez-vous de garder à l'esprit les recommandations et pratiques de sécurité ci-dessus.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!