freeCodeCamp/curriculum/challenges/italian/09-information-security/information-security-with-h.../ask-browsers-to-access-your...

2.5 KiB
Raw Blame History

id title challengeType forumTopicId dashedName
587d8248367417b2b2512c3c Chiedere ai browser di accedere al tuo sito solo tramite HTTPS con helmet.hsts() 2 301573 ask-browsers-to-access-your-site-via-https-only-with-helmet-hsts

--description--

Come promemoria, questo progetto verrà costruito a partire dalla seguente bozza su Replit, o clonato da GitHub.

HTTP Strict Transport Security (HSTS) è una politica di sicurezza web che aiuta a proteggere i siti Web dagli attacchi di downgrade del protocollo e dal dirottamento dei cookie. Se è possibile accedere al sito web tramite HTTPS è possibile chiedere ai browser dellutente di evitare di utilizzare HTTP non protetto. Impostando l'intestazione Strict-Transport-Security, si dice ai browser di utilizzare HTTPS per le future richieste in un determinato lasso di tempo. Questo funzionerà per le richieste pervenute dopo la richiesta iniziale.

--instructions--

Configurare helmet.hsts() in modo che utilizza HTTPS per i prossimi 90 giorni. Passa l'oggetto di configurazione {maxAge: timeInSeconds, force: true}. Puoi creare una variabile ninetyDaysInSeconds = 90*24*60*60; da usare per il timeInSeconds. Replit ha già hsts abilitato. Per sovrascrivere le sue impostazioni è necessario impostare il campo "force" a true nell'oggetto di configurazione. Intercetteremo e ripristineremo l'intestazione di Replit, dopo averla ispezionata per il test.

Nota: la configurazione di HTTPS su un sito web personalizzato richiede l'acquisizione di un dominio e di un certificato SSL/TLS.

--hints--

Il middleware helmet.hsts() deve essere montato correttamente

(getUserInput) =>
  $.get(getUserInput('url') + '/_api/app-info').then(
    (data) => {
      assert.include(data.appStack, 'hsts');
      assert.property(data.headers, 'strict-transport-security');
    },
    (xhr) => {
      throw new Error(xhr.responseText);
    }
  );

maxAge deve essere uguale a 7776000 s (90 giorni)

(getUserInput) =>
  $.get(getUserInput('url') + '/_api/app-info').then(
    (data) => {
      assert.match(
        data.headers['strict-transport-security'],
        /^max-age=7776000;?/
      );
    },
    (xhr) => {
      throw new Error(xhr.responseText);
    }
  );

--solutions--

/**
  Backend challenges don't need solutions, 
  because they would need to be tested against a full working project. 
  Please check our contributing guidelines to learn more.
*/