freeCodeCamp/curriculum/challenges/italian/09-information-security/information-security-with-h.../disable-dns-prefetching-wit...

1.7 KiB

id title challengeType forumTopicId dashedName
587d8248367417b2b2512c3d Disabilitare il precaricamento DNS con helmet.dnsPrefetchControl() 2 301577 disable-dns-prefetching-with-helmet-dnsprefetchcontrol

--description--

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

Per migliorare le prestazioni, la maggior parte dei browser precarica i record DNS per i link in una pagina. In questo modo l'ip di destinazione è già noto quando l'utente fa clic su un link. Questo può portare ad un uso eccessivo del servizio DNS (se possedete un grande sito web, visitato da milioni di persone…), problemi di privacy (un origliatore potrebbe dedurre che sei su una determinata pagina), o un'alterazione delle statistiche di pagina (alcuni link possono apparire visitati anche se non lo sono). Se hai esigenze di sicurezza elevata, è possibile disabilitare il precaricamento DNS, al costo di una perdita di prestazioni.

--instructions--

Usa il metodo helmet.dnsPrefetchControl() sul tuo server.

--hints--

Il middleware helmet.dnsPrefetchControl() deve essere montato correttamente

(getUserInput) =>
  $.get(getUserInput('url') + '/_api/app-info').then(
    (data) => {
      assert.include(data.appStack, 'dnsPrefetchControl');
      assert.equal(data.headers['x-dns-prefetch-control'], 'off');
    },
    (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.
*/