Appliquer une version minimale de TLS - AWS SDK for JavaScript

Nous avons annoncé la sortie end-of-support de la AWS SDK for JavaScript v2. Nous vous recommandons de migrer vers la AWS SDK for JavaScript version 3. Pour les dates, les détails supplémentaires et les informations sur la façon de migrer, reportez-vous à l'annonce associée.

Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.

Appliquer une version minimale de TLS

Important

La AWS SDK for JavaScript v2 négocie automatiquement la version TLS de plus haut niveau prise en charge par un point de terminaison de AWS service donné. Vous pouvez éventuellement appliquer une version TLS minimale requise par votre application, telle que TLS 1.2 ou 1.3, mais veuillez noter que TLS 1.3 n'est pas pris en charge par certains points de terminaison du AWS service. Certains appels peuvent donc échouer si vous appliquez le protocole TLS 1.3.

Pour renforcer la sécurité lors de la communication avec les AWS services, configurez le AWS SDK for JavaScript pour utiliser le protocole TLS 1.2 ou version ultérieure.

Transport Layer Security (TLS) est un protocole utilisé par les navigateurs web et d'autres applications pour assurer la confidentialité et l'intégrité des données échangées sur un réseau.

Vérifier et appliquer TLS dans Node.js

Lorsque vous utilisez le AWS SDK for JavaScript with Node.js, la couche de sécurité Node.js sous-jacente est utilisée pour définir la version TLS.

Node.js 12.0.0 et versions ultérieures utilisent une version minimale d'OpenSSL 1.1.1b, qui prend en charge le protocole TLS 1.3. La AWS SDK for JavaScript version 3 utilise par défaut le protocole TLS 1.3 lorsqu'il est disponible, mais utilise par défaut une version inférieure si nécessaire.

Vérifier la version d'OpenSSL et TLS

Pour obtenir la version d'OpenSSL utilisée par Node.js sur votre ordinateur, exécutez la commande suivante.

node -p process.versions

La version d'OpenSSL dans la liste est la version utilisée par Node.js, comme illustré dans l'exemple suivant.

openssl: '1.1.1b'

Pour obtenir la version de TLS utilisée par Node.js sur votre ordinateur, démarrez le shell Node et exécutez les commandes suivantes, dans l'ordre.

> var tls = require("tls"); > var tlsSocket = new tls.TLSSocket(); > tlsSocket.getProtocol();

La dernière commande génère la version TLS, comme illustré dans l'exemple suivant.

'TLSv1.3'

Node.js utilise par défaut cette version de TLS et tente de négocier une autre version de TLS si un appel échoue.

Appliquer une version minimale de TLS

Node.js négocie une version de TLS lorsqu'un appel échoue. Vous pouvez appliquer la version TLS minimale autorisée au cours de cette négociation, soit lors de l'exécution d'un script depuis la ligne de commande, soit par requête dans votre JavaScript code.

Pour spécifier la version TLS minimale à partir de la ligne de commande, vous devez utiliser Node.js version 11.0.0 ou une version ultérieure. Pour installer une version spécifique de Node.js, installez d'abord Node Version Manager (nvm) en suivant les étapes décrites dans Installation et mise à jour de Node Version Manager. Ensuite, exécutez les commandes suivantes pour installer et utiliser une version spécifique de Node.js.

nvm install 11 nvm use 11
Enforcing TLS 1.2

Pour faire en sorte que TLS 1.2 soit la version minimale autorisée, spécifiez l'argument --tls-min-v1.2 lors de l'exécution de votre script, comme indiqué dans l'exemple suivant.

node --tls-min-v1.2 yourScript.js

Pour spécifier la version TLS minimale autorisée pour une demande spécifique dans votre JavaScript code, utilisez le httpOptions paramètre pour spécifier le protocole, comme indiqué dans l'exemple suivant.

const https = require("https"); const {NodeHttpHandler} = require("@aws-sdk/node-http-handler"); const {DynamoDBClient} = require("@aws-sdk/client-dynamodb"); const client = new DynamoDBClient({ region: "us-west-2", requestHandler: new NodeHttpHandler({ httpsAgent: new https.Agent( { secureProtocol: 'TLSv1_2_method' } ) }) });
Enforcing TLS 1.3

Pour confirmer que TLS 1.3 est la version minimale autorisée, spécifiez l'--tls-min-v1.3argument lors de l'exécution de votre script, comme indiqué dans l'exemple suivant.

node --tls-min-v1.3 yourScript.js

Pour spécifier la version TLS minimale autorisée pour une demande spécifique dans votre JavaScript code, utilisez le httpOptions paramètre pour spécifier le protocole, comme indiqué dans l'exemple suivant.

const https = require("https"); const {NodeHttpHandler} = require("@aws-sdk/node-http-handler"); const {DynamoDBClient} = require("@aws-sdk/client-dynamodb"); const client = new DynamoDBClient({ region: "us-west-2", requestHandler: new NodeHttpHandler({ httpsAgent: new https.Agent( { secureProtocol: 'TLSv1_3_method' } ) }) });

Vérifier et appliquer TLS dans un script de navigateur

Lorsque vous utilisez le SDK JavaScript dans un script de navigateur, les paramètres du navigateur contrôlent la version de TLS utilisée. La version de TLS utilisée par le navigateur ne peut pas être découverte ou définie par script et doit être configurée par l'utilisateur. Pour vérifier et appliquer la version de TLS utilisée dans un script de navigateur, veuillez consulter les instructions de votre navigateur spécifique.

Microsoft Internet Explorer
  1. Ouvrez Internet Explorer.

  2. Dans la barre de menu, choisissez Outils - Options Internet - onglet Avancé.

  3. Faites défiler la page jusqu'à la catégorie de sécurité, cochez manuellement la case Utiliser TLS 1.2.

  4. Cliquez sur OK.

  5. Fermez votre navigateur et redémarrez Internet Explorer.

Microsoft Edge
  1. Dans le champ de recherche du menu Windows, tapez Options Internet.

  2. Sous Meilleure correspondance, cliquez sur Options Internet.

  3. Dans la fenêtre Propriétés Internet, sous l'onglet Avancé, faites défiler la page jusqu'à la section Sécurité.

  4. Cochez la case User TLS 1.2.

  5. Cliquez sur OK.

Google Chrome
  1. Ouvrez Google Chrome.

  2. Cliquez sur Alt F et sélectionnez Paramètres.

  3. Faites défiler l'écran vers le bas et sélectionnez Afficher les paramètres avancés... .

  4. Faites défiler la page jusqu'à la section Système et cliquez sur Ouvrir les paramètres du proxy... .

  5. Sélectionnez l'onglet Avancé.

  6. Faites défiler la page jusqu'à la catégorie de sécurité, cochez manuellement la case Utiliser TLS 1.2.

  7. Cliquez sur OK.

  8. Fermez votre navigateur et redémarrez Google Chrome.

Mozilla Firefox
  1. Ouvrez Firefox.

  2. Dans la barre d'adresse, tapez about:config et appuyez sur Entrée.

  3. Dans le champ de recherche, saisissez tls. Recherchez et double-cliquez sur l'entrée relative à security.tls.version.min.

  4. Définissez la valeur entière sur 3 pour forcer le protocole TLS 1.2 à être le protocole par défaut.

  5. Cliquez sur OK.

  6. Fermez votre navigateur et redémarrez Mozilla Firefox.

Apple Safari

Il n'existe aucune option permettant d'activer les protocoles SSL. Si vous utilisez Safari version 7 ou supérieure, le protocole TLS 1.2 est automatiquement activé.