Module 5
Détection des vulnérabilités des applications Web
Dernière mise à jour le: 28 Août 2024
Modifier cette page sur GitHubModule 5
Dernière mise à jour le: 28 Août 2024
Modifier cette page sur GitHubD’une manière ou d’une autre, chaque application Web accepte et traite des entrées non fiables. Ces entrées proviennent généralement des utilisateurs finaux et de leurs navigateurs, mais peuvent également provenir d’autres sites Web ou systèmes backend. Selon l’endroit où ces informations circulent, le traitement des données peut avoir des effets indésirables sur le site Web ou ses utilisateurs.
Après avoir terminé ce sous-thème, les participants seront en mesure de trouver des vulnérabilités dans un site Web réel, plutôt que de comprendre les vulnérabilités individuelles de manière isolée.
Après avoir terminé les sous-thèmes précédents, vous devriez avoir une bonne compréhension des vulnérabilités individuelles. Bien que cela puisse être suffisant pour vous guider dans la résolution des vulnérabilités ou pour effectuer des analyses d’investigation dans une violation d’application Web, cela sera insuffisant si vous souhaitez trouver ces vulnérabilités dans une application Web. Tandis que les exercices pratiques précédents étaient des puzzles ciblés vous mettant au défi d’activer une vulnérabilité dans une seule entrée, la plupart des entrées ne seront vulnérables à rien dans les applications Web réelles. Votre défi consistera à trouver ces entrées rares qui présentent une vulnérabilité.
Pour vous assister dans cette tâche, il est utile de disposer d’un cadre mental pour guider vos tests. Cela servira à organiser vos pensées et vos notes sur ce que vous testez, et pourra également servir de liste de contrôle. Ne sous-estimez pas la puissance des listes de contrôle ! Les listes de contrôle sont la raison pour laquelle le transport aérien est sûr, et l’introduction de listes de contrôle dans les unités de soins intensifs des hôpitaux d’un État des États-Unis a réduit les taux d’infection de ⅓ et a permis de sauver plus de 1 500 vies en plus d’un an et demi. Toute tâche complexe et sujette aux erreurs bénéficiera grandement d’une liste de contrôle, et le contrôle des applications Web est extrêmement complexe et sujet aux erreurs.
Dans ce sous-thème, vous allez tester une application Web délibérément vulnérable. Vous tenterez de trouver toutes les vulnérabilités dans l’application et de documenter ces vulnérabilités.
Pour commencer, vous aurez besoin d’une application à tester. Une (mauvaise) option consisterait à trouver un site Web aléatoire sur Internet afin de tenter de vous y introduire. Ce n’est pas une bonne idée pour deux raisons. La première est que c’est une pratique contraire à l’éthique (même si vos intentions sont bonnes, que se passera-t-il si vous endommagez accidentellement le site) et, selon l’endroit où vous vivez, probablement illégal. La deuxième est que, surtout au début, il est impossible de déterminer de façon fiable si un site est sécurisé ou si vos capacités de test sont insuffisantes.
La solution consiste à vous exercer sur un site intentionnellement vulnérable. Ces sites sont conçus expressément pour que les apprenants s’entraînent à trouver et à exploiter les vulnérabilités. Ils peuvent être testés sans souci d’éthique ou de légalité (la plupart sont téléchargeables pour vous permettre de les tester sur votre propre ordinateur), et comprennent certaines vulnérabilités connues afin de vous permettre d’évaluer vos capacités. Pour ce sous-thème, nous utiliserons l’application Web vulnérable Juice Shop de l’OWASP.
Ensuite, vous aurez besoin d’une méthodologie pour guider vos tests. À mesure que vous acquerrez de l’expérience, vous commencerez probablement à élaborer votre propre cadre et vos propres procédures qui conviendront à votre style de travail préféré. Cependant, vous aurez besoin de ce guide pour commencer. Dans le cadre de ce parcours d’apprentissage, nous utiliserons une méthodologie écrite par Tanner Prynn, qui est à peu près conforme aux normes utilisées par la plupart des pratiques professionnelles de test d’intrusion d’applications Web. Ce document méthodologique est un bon compromis entre la brièveté (comparez ses 23 pages imprimées aux 465 pages du guide de test de l’OWASP) et l’exhaustivité. Il ne contient pas toutes les vulnérabilités possibles et ne propose pas de directives complètes pour tester les vulnérabilités qu’il couvre, mais il devrait être suffisant pour vous permettre de tirer parti de votre expertise.
En plus d’avoir un cadre et une liste de contrôle de ce que vous avez testé, il est extrêmement important que vous gardiez des notes détaillées. Les notes structurées comme les listes de contrôle montrent rapidement leurs limites. Voici quelques exemples d’utilisation des notes libres :
Enfin, pour que votre travail acharné soit utile à tout le monde, vous devrez documenter les vulnérabilités que vous trouverez. En général, vous testerez le site Web de quelqu’un d’autre et produirez une sorte de rapport, formel ou informel. Dans tous les cas, les principaux objectifs du rapport devraient être de communiquer :
En règle générale, les rapports comportent une section d’introduction qui décrit ce qui a été testé et ce qui n’a pas été testé, puis une autre section contenant des détails sur chaque vulnérabilité trouvée. Approfondissons chaque section.
La section d’introduction contient généralement des informations sur l’application testée. Les détails tels que l’URL de l’application, l’environnement dans lequel elle a été testée (p. ex., production vs staging) et la plage de dates dans laquelle les tests ont été effectués sont importants et permettent aux développeurs de contextualiser les tests par rapport à leurs cycles de développement et de publication.
Il est également important d’inclure des informations sur les objectifs des tests. Pour certains tests, l’objectif pourrait être de tester uniquement les vulnérabilités susceptibles d’entraîner une prise de contrôle complète de l’infrastructure du serveur Web. Pour d’autres, l’objectif pourrait être d’effectuer un test très approfondi et complet. Pour la plupart des tests d’applications Web, le test doit être effectué dans un laps de temps donné, et l’objectif consiste à identifier le plus de vulnérabilités et le plus d’impacts possibles dans ce délai. L’inclusion de cette information marque la ligne entre la description de ce qui a été testé et de ce qui n’a pas été testé.
Enfin, si des types de tests ont été exclus, si des parties du site n’ont pas été testées ou si d’autres restrictions ont empêché l’atteinte des objectifs du test, il est important de les consigner dans le rapport. De cette façon, les propriétaires du site ne seront pas au courant des zones qui pourraient contenir des vulnérabilités inconnues.
Les rapports d’évaluation de la sécurité des applications Web comportent généralement une autre section qui énumère les détails de chaque vulnérabilité trouvée. Il s’agit de la partie la plus importante du rapport, et il est important qu’elle soit claire et compréhensible. Elle prend généralement la forme d’une liste pour chaque vulnérabilité, qui comprend des éléments comme :
Parfois, une méthode plus structurée sera utilisée pour obtenir une cote de risque, comme le CVSS. Notez que ces méthodes sont soit suffisamment rigides pour parfois générer des évaluations de risque qui ne reflètent pas la réalité, soit suffisamment flexibles pour ne pas fournir de cohérence significative. Pour obtenir plus d’informations sur la détermination des cotes de risque, consultez la méthodologie de cotation de risque de l’OWASP et les lignes directrices de cotation de risque pour les programmes de bug bounty tels que Bugcrowd.
Bien que ce qui précède représente la quantité minimale raisonnable d’informations à inclure dans un rapport, il est acceptable (et souvent conseillé) d’en inclure davantage. Les sociétés professionnelles d’évaluation de la sécurité produisent parfois des rapports qui sont accessibles au public. La lecture de ces rapports peut vous inspirer pour vos propres rapports, ainsi que fournir des informations sur les vulnérabilités existantes et sur leurs cotes de risque. Ce GitHub contient un large référentiel de rapports publics. Notez que de nombreux rapports publics ne contiennent pas de détails sur les vulnérabilités, contrairement à d’autres tels que les suivants :
Une dernière remarque au sujet des rapports : il est très important que vous consigniez vos conclusions dans votre rapport pendant que vous effectuez les tests. En règle générale, les nouveaux testeurs préféreront poursuivre les tests, en pensant qu’il sera facile de rédiger le rapport plus tard. C’est une erreur. Ils terminent leurs tests, puis ont des difficultés à terminer leur rapport et doivent souvent revenir en arrière et refaire d’autres tests. Cela peut sembler inefficace d’interrompre les tests afin de consigner une vulnérabilité dans votre rapport, surtout si vous devez mettre à jour cette vulnérabilité plus tard. C’est pourtant la méthode la plus efficace à suivre.
La majeure partie de ce parcours d’apprentissage concerne cet exercice pratique. Ici, vous allez rassembler toutes les techniques que vous avez apprises dans les sous-thèmes précédents pour trouver des vulnérabilités dans une application Web réelle. Cela devrait vous prendre un certain temps. En règle générale, il faudrait jusqu’à une semaine à un intervenant qualifié pour évaluer pleinement une application comme Juice Shop, et vous n’avez pas encore ce statut. Si vous vous retrouvez en difficulté, dites-vous que c’est normal. Résistez à la tentation de chercher des explications ou des corrigés, ou de regarder les sections suivantes de ce parcours d’apprentissage. Les difficultés sont une partie naturelle et importante du processus d’apprentissage.
Vous ne devriez pas vous attendre à détecter une instance de chaque vulnérabilité. Essayez, mais ne soyez pas trop déçu(e) si vous n’y arrivez pas. Essayez également de ne pas trop vous demander si vous avez fait suffisamment de tests. Il est littéralement impossible de savoir avec certitude que vous avez trouvé toutes les vulnérabilités dans toutes les applications, sauf dans les plus limitées.
Au lieu de cela, passez en revue la méthodologie et essayez de tester complètement le site Web. Si vous avez des choses à revoir dans vos notes, revoyez-les brièvement, mais ne consacrez pas trop de temps à ça. N’oubliez pas qu’il s’agit d’un exercice.
Si vous avez un mentor, passez en revue votre rapport avec lui. Il vous sera probablement utile de consulter un ou plusieurs des articles concernant des vulnérabilités que d’autres personnes ont trouvées, en voici un. Notez que Juice Shop contient de nombreux défis. Les défis consistent principalement à exploiter les vulnérabilités. La meilleure chose à faire est de demander à votre mentor de vous donner des conseils sur les vulnérabilités que vous avez manquées, par exemple sur quelle page elles se trouvent, puis d’essayer de les trouver par vous-même. Si vous vous retrouvez coincé(e), demandez à votre mentor de vous expliquer la vulnérabilité.
Si vous n’avez pas de mentor, vous pouvez vous auto-encadrer pour ce sous-thème. Vous pouvez simplement effectuer les activités ci-dessus. Au lieu d’obtenir un indice de votre mentor, jetez un coup d’œil aux défis et essayez de comprendre la vulnérabilité associée. Encore une fois, si vous êtes coincé(e), il existe de nombreux guides aux formats écrits et vidéo.
La liste de contrôle
Gratuit pour les premiers articles de la publication, les suivants nécessitent un abonnementUn article sur l’importance d’utiliser des listes de contrôle dans de nombreuses professions différentes
Répertoire des applications Web vulnérables de l'OWASP
GratuitUne liste d’applications Web comprenant des vulnérabilités connues qui peuvent être utilisées pour tester les compétences d’évaluation Web et de test d’intrusion
Méthodologie pour les tests de sécurité des applications Web de haute qualité
GratuitUne liste exhaustive (et, pour citer l’auteur, une liste « obstinée ») des questions qu’un protecteur numérique devrait examiner lors de l’évaluation de la sécurité des applications Web
Samy (vers)
GratuitExemple de code malveillant exploitant des vulnérabilités XSS
Un aperçu du CVSS
GratuitUn aperçu du système commun de notation des vulnérabilités, une approche structurée utilisée pour évaluer la gravité des vulnérabilités
Méthodologie de notation de risque de l'OWASP
GratuitIl existe de nombreuses façons d’évaluer les risques de vulnérabilités et d’exploitations de failles, et l’OWASP en propose une qui est décrite ici en détail.
Taxonomie des vulnérabilités de Bugcrowd
GratuitUne autre façon de suivre les risques de vulnérabilités, cette fois par Bugcrowd
Rapports publics de tests d'intrusion
GratuitUne liste publique des rapports de tests d’intrusion produits
Félicitations pour avoir terminé Module 5!
Cochez la case pour confirmer que vous avez terminé et passer au module suivant.
Marque le module actuel comme terminé et enregistre la progression pour l'utilisateur.
Vous avez complété tous les modules de ce parcours d'apprentissage.