Test de sécurité - Guide rapide

Les tests de sécurité sont très importants pour protéger le système des activités malveillantes sur le Web.

Qu'est-ce que les tests de sécurité?

Les tests de sécurité sont une technique de test pour déterminer si un système d'information protège les données et maintient les fonctionnalités comme prévu. Les tests de sécurité ne garantissent pas la sécurité complète du système, mais il est important d'inclure les tests de sécurité dans le cadre du processus de test.

Les tests de sécurité prennent les six mesures suivantes pour fournir un environnement sécurisé -

  • Confidentiality - Il protège contre la divulgation d'informations à des destinataires involontaires.

  • Integrity - Il permet de transférer les informations souhaitées exactes et correctes des expéditeurs aux destinataires prévus.

  • Authentication - Il vérifie et confirme l'identité de l'utilisateur.

  • Authorization - Il spécifie les droits d'accès aux utilisateurs et aux ressources.

  • Availability - Il assure la disponibilité des informations sur les besoins.

  • Non-repudiation - Il garantit qu'il n'y a pas de refus de l'expéditeur ou du destinataire pour avoir envoyé ou reçu le message.

Exemple

La détection d'une faille de sécurité dans une application Web implique des étapes complexes et une réflexion créative. Parfois, un simple test peut exposer le risque de sécurité le plus grave. Vous pouvez essayer ce test très basique sur n'importe quelle application Web -

  • Connectez-vous à l'application Web en utilisant des informations d'identification valides.

  • Déconnectez-vous de l'application Web.

  • Cliquez sur le bouton RETOUR du navigateur.

  • Vérifiez si vous êtes invité à vous reconnecter ou si vous pouvez revenir à la page de connexion.

Les tests de sécurité peuvent être considérés comme une attaque contrôlée sur le système, qui découvre les failles de sécurité de manière réaliste. Son objectif est d'évaluer l'état actuel d'un système informatique. Il est également connu sous le nom depenetration test ou plus populairement comme ethical hacking.

Le test de pénétration se fait en phases et ici dans ce chapitre, nous discuterons du processus complet. Une documentation appropriée doit être faite à chaque phase afin que toutes les étapes nécessaires pour reproduire l'attaque soient facilement disponibles. La documentation sert également de base au rapport détaillé que les clients reçoivent à l'issue d'un test d'intrusion.

Test de pénétration - Workflow

Le test de pénétration comprend quatre phases principales -

  • Impression de pied
  • Scanning
  • Enumeration
  • Exploitation

Ces quatre étapes sont répétées plusieurs fois, ce qui va de pair avec le SDLC normal.

Un logiciel malveillant (malware) est tout logiciel qui donne un contrôle partiel ou total du système à l'attaquant / créateur de malware.

Malwares

Diverses formes de logiciels malveillants sont répertoriées ci-dessous -

  • Virus- Un virus est un programme qui crée des copies de lui-même et insère ces copies dans d'autres programmes informatiques, fichiers de données ou dans le secteur d'amorçage du disque dur. En cas de réplication réussie, les virus provoquent une activité nuisible sur les hôtes infectés, comme le vol d'espace disque ou de temps CPU.

  • Worm - Un ver est un type de malware qui laisse une copie de lui-même dans la mémoire de chaque ordinateur sur son chemin.

  • Trojan - Le cheval de Troie est un type de logiciel malveillant qui ne se réplique pas automatiquement et qui contient du code malveillant qui, lors de son exécution, entraîne la perte ou le vol de données ou peut endommager le système.

  • Adware- Adware, également connu sous le nom de freeware ou pitchware, est un logiciel informatique gratuit qui contient des publicités commerciales de jeux, de barres d'outils de bureau et d'utilitaires. Il s'agit d'une application Web qui collecte les données du navigateur Web pour cibler les publicités, en particulier les fenêtres contextuelles.

  • Spyware- Un logiciel espion est un logiciel d'infiltration qui surveille de manière anonyme les utilisateurs, ce qui permet à un pirate informatique d'obtenir des informations sensibles de l'ordinateur de l'utilisateur. Les logiciels espions exploitent les vulnérabilités des utilisateurs et des applications qui sont souvent associées aux téléchargements de logiciels gratuits en ligne ou aux liens sur lesquels les utilisateurs cliquent.

  • Rootkit - Un rootkit est un logiciel utilisé par un pirate informatique pour obtenir un accès de niveau administrateur à un ordinateur / réseau qui est installé via un mot de passe volé ou en exploitant une vulnérabilité du système à l'insu de la victime.

Mesures préventives

Les mesures suivantes peuvent être prises pour éviter la présence de logiciels malveillants dans un système -

  • Assurez-vous que le système d'exploitation et les applications sont à jour avec les correctifs / mises à jour.

  • N'ouvrez jamais les e-mails étranges, en particulier ceux avec des pièces jointes.

  • Lorsque vous téléchargez sur Internet, vérifiez toujours ce que vous installez. Ne cliquez pas simplement sur OK pour fermer les fenêtres contextuelles. Vérifiez l'éditeur avant d'installer l'application.

  • Installez un logiciel antivirus.

  • Assurez-vous de scanner et de mettre à jour régulièrement les programmes antivirus.

  • Installez le pare-feu.

  • Activez et utilisez toujours les fonctionnalités de sécurité fournies par les navigateurs et les applications.

Logiciel anti-malware

Les logiciels suivants aident à supprimer les malwares d'un système -

  • Microsoft Security Essentials
  • Microsoft Windows Defender
  • AVG Internet Security
  • Spybot - Rechercher et détruire
  • Avast! Édition familiale pour un usage personnel
  • Sécurité Internet Panda
  • MacScan pour Mac OS et Mac OS X

Comprendre le protocole est très important pour bien comprendre les tests de sécurité. Vous pourrez apprécier l'importance du protocole lorsque nous intercepterons les données par paquets entre le serveur Web et le client.

Protocole HTTP

Le protocole HTTP (Hypertext Transfer Protocol) est un protocole de niveau application pour les systèmes d'information distribués, collaboratifs et hypermédia. C'est la base de la communication de données pour le World Wide Web depuis 1990. HTTP est un protocole générique et sans état qui peut être utilisé à d'autres fins également en utilisant l'extension de ses méthodes de requête, codes d'erreur et en-têtes.

Fondamentalement, HTTP est un protocole de communication basé sur TCP / IP, utilisé pour fournir des données telles que des fichiers HTML, des fichiers image, des résultats de requêtes, etc. sur le Web. Il fournit un moyen standardisé pour les ordinateurs de communiquer entre eux. La spécification HTTP spécifie comment les données demandées par les clients sont envoyées au serveur et comment les serveurs répondent à ces demandes.

Caractéristiques de base

Les trois fonctionnalités de base suivantes font de HTTP un protocole simple mais puissant:

  • HTTP is connectionless- Le client HTTP, c'est-à-dire le navigateur lance une requête HTTP. Après avoir fait une demande, le client se déconnecte du serveur et attend une réponse. Le serveur traite la demande et rétablit la connexion avec le client pour renvoyer la réponse.

  • HTTP is media independent- Tout type de données peut être envoyé par HTTP tant que le client et le serveur savent comment gérer le contenu des données. Cela est nécessaire pour le client et le serveur pour spécifier le type de contenu à l'aide du type MIME approprié.

  • HTTP is stateless- HTTP est un sans connexion et c'est un résultat direct que HTTP est un protocole sans état. Le serveur et le client ne se reconnaissent que lors d'une requête en cours. Ensuite, ils s'oublient tous les deux. En raison de cette nature du protocole, ni le client ni le navigateur ne peuvent conserver les informations entre les différentes demandes sur les pages Web.

HTTP / 1.0 utilise une nouvelle connexion pour chaque échange de demande / réponse tandis que la connexion HTTP / 1.1 peut être utilisée pour un ou plusieurs échanges de demande / réponse.

Architecture

Le diagramme suivant montre une architecture très basique d'une application Web et décrit où réside HTTP -

Le protocole HTTP est un protocole de requête / réponse basé sur l'architecture client / serveur où le navigateur Web, les robots et les moteurs de recherche, etc. agissent comme des clients HTTP et le serveur Web agit comme un serveur.

  • Client - Le client HTTP envoie une requête au serveur sous la forme d'une méthode de requête, d'un URI et d'une version de protocole, suivie d'un message de type MIME contenant des modificateurs de requête, des informations sur le client et le contenu du corps possible via une connexion TCP / IP.

  • Server - Le serveur HTTP répond avec une ligne d'état, comprenant la version du protocole du message et un code de réussite ou d'erreur, suivi d'un message de type MIME contenant des informations sur le serveur, des méta-informations d'entité et un éventuel contenu de corps d'entité.

HTTP - Inconvénients

  • HTTP n'est pas un protocole complètement sécurisé.

  • HTTP utilise le port 80 comme port par défaut pour la communication.

  • HTTP fonctionne au niveau de la couche d'application. Il doit créer plusieurs connexions pour le transfert de données, ce qui augmente les frais d'administration.

  • Aucun cryptage / certificat numérique n'est requis pour utiliser HTTP.

Détails du protocole HTTP

Afin de comprendre en profondeur le protocole HTTP, cliquez sur chacun des liens ci-dessous.

  • HTTP Parameters

  • HTTP Messages

  • HTTP Requests

  • HTTP Responses

  • HTTP Methods

  • HTTP Status Codes

  • HTTP Header Fields

  • HTTP Security

HTTPS (Hypertext Transfer Protocol over Secure Socket Layer) ou HTTP over SSL est un protocole Web développé par Netscape. Ce n'est pas un protocole mais c'est juste le résultat de la superposition du HTTP au-dessus de SSL / TLS (Secure Socket Layer / Transport Layer Security).

En bref, HTTPS = HTTP + SSL

Quand HTTPS est-il requis?

Lorsque nous naviguons, nous envoyons et recevons normalement des informations en utilisant le protocole HTTP. Cela conduit donc quiconque à écouter la conversation entre notre ordinateur et le serveur Web. Plusieurs fois, nous devons échanger des informations sensibles qui doivent être sécurisées et empêcher tout accès non autorisé.

Protocole Https utilisé dans les scénarios suivants -

  • Sites Web bancaires
  • Passerelle de paiement
  • Sites de shopping
  • Toutes les pages de connexion
  • Applications de messagerie

Fonctionnement de base de HTTPS

  • La clé publique et les certificats signés sont requis pour le serveur dans le protocole HTTPS.

  • Demandes du client pour la page https: //

  • Lors de l'utilisation d'une connexion https, le serveur répond à la connexion initiale en proposant une liste de méthodes de chiffrement prises en charge par le serveur Web.

  • En réponse, le client sélectionne une méthode de connexion, et le client et le serveur échangent des certificats pour authentifier leurs identités.

  • Une fois que cela est fait, le serveur Web et le client échangent les informations chiffrées après s'être assuré que tous deux utilisent la même clé et que la connexion est fermée.

  • Pour héberger des connexions https, un serveur doit avoir un certificat de clé publique, qui intègre les informations de clé avec une vérification de l'identité du propriétaire de la clé.

  • Presque tous les certificats sont vérifiés par un tiers afin que les clients soient assurés que la clé est toujours sécurisée.

Qu'est-ce que l'encodage et le décodage?

Le codage est le processus consistant à placer une séquence de caractères tels que des lettres, des chiffres et d'autres caractères spéciaux dans un format spécialisé pour une transmission efficace.

Le décodage est le processus de conversion d'un format codé dans la séquence originale de caractères. C'est complètement différent du cryptage que nous interprétons généralement mal.

Le codage et le décodage sont utilisés dans les communications et le stockage de données. Le codage ne doit PAS être utilisé pour transporter des informations sensibles.

Encodage d'URL

Les URL ne peuvent être envoyées sur Internet qu'en utilisant le jeu de caractères ASCII et il existe des cas où l'URL contient des caractères spéciaux en dehors des caractères ASCII, elle doit être codée. Les URL ne contiennent pas d'espaces et sont remplacées par un signe plus (+) ou par% 20.

Encodage ASCII

Le navigateur (côté client) encodera l'entrée en fonction du jeu de caractères utilisé dans la page Web et le jeu de caractères par défaut en HTML5 est UTF-8.

Le tableau suivant montre le symbole ASCII du caractère et son symbole égal et enfin son remplacement qui peut être utilisé dans l'URL avant de le transmettre au serveur -

ASCII symbole Remplacement
<32   Encode avec% xx où xx est la représentation hexadécimale du caractère.
32 espace + ou% 20
33 ! % 21
34 " % 22
35 # % 23
36 $ % 24
37 % % 25
38 & % 26
39 ' % 27
40 ( % 28
41 ) % 29
42 * *
43 + % 2B
44 , % 2C
45 - -
46 . .
47 / % 2F
48 0 0
49 1 1
50 2 2
51 3 3
52 4 4
53 5 5
54 6 6
55 sept sept
56 8 8
57 9 9
58 : % 3A
59 ; % 3B
60 > % 3C
61 = % 3D
62 > % 3E
63 ? % 3F
64 @ % 40
65 UNE UNE
66 B B
67 C C
68
69 E E
70 F F
71 g g
72 H H
73 je je
74 J J
75 K K
76 L L
77 M M
78 N N
79 O O
80 P P
81 Q Q
82 R R
83 S S
84 T T
85 U U
86 V V
87 W W
88 X X
89 Oui Oui
90 Z Z
91 [ % 5B
92 \ % 5C
93 ] % 5D
94 ^ % 5E
95 _ _
96 » % 60
97 une une
98 b b
99 c c
100
101 e e
102 F F
103 g g
104 h h
105 je je
106 j j
107 k k
108 l l
109 m m
110 n n
111 o o
112 p p
113 q q
114 r r
115 s s
116 t t
117 u u
118 v v
119 w w
120 X X
121 y y
122 z z
123 { % 7B
124 | % 7C
125 } % 7D
126 ~ % 7E
127   % 7F
> 127   Encode avec% xx où xx est la représentation hexadécimale du caractère

Qu'est-ce que la cryptographie?

La cryptographie est la science pour crypter et décrypter les données qui permet aux utilisateurs de stocker des informations sensibles ou de les transmettre sur des réseaux non sécurisés afin qu'elles ne puissent être lues que par le destinataire prévu.

Les données qui peuvent être lues et comprises sans aucune mesure particulière sont appelées plaintext, tandis que la méthode de déguisement du texte clair afin de cacher sa substance est appelée encryption.

Le texte brut chiffré est appelé texte chiffré et le processus de restauration des données chiffrées en texte brut est appelé decryption.

  • La science de l'analyse et de la rupture de la communication sécurisée est connue sous le nom de cryptanalyse. Les personnes qui exécutent la même chose sont également appelées assaillants.

  • La cryptographie peut être forte ou faible et la force est mesurée par le temps et les ressources nécessaires pour récupérer le texte en clair réel.

  • Par conséquent, un outil de décodage approprié est nécessaire pour déchiffrer les messages chiffrés forts.

  • Il existe des techniques cryptographiques avec lesquelles même un milliard d'ordinateurs effectuant un milliard de chèques par seconde, il n'est pas possible de déchiffrer le texte.

  • Comme la puissance de calcul augmente de jour en jour, il faut rendre les algorithmes de chiffrement très puissants afin de protéger les données et les informations critiques des attaquants.

Comment fonctionne le cryptage?

Un algorithme cryptographique fonctionne en combinaison avec une clé (peut être un mot, un nombre ou une phrase) pour crypter le texte en clair et le même texte en clair crypte en différents textes chiffrés avec des clés différentes.

Par conséquent, les données cryptées dépendent complètement du couple de paramètres tels que la force de l'algorithme cryptographique et le secret de la clé.

Techniques de cryptographie

Symmetric Encryption- La cryptographie conventionnelle, également appelée cryptage conventionnel, est la technique dans laquelle une seule clé est utilisée à la fois pour le cryptage et le décryptage. Par exemple, DES, algorithmes Triple DES, MARS par IBM, RC2, RC4, RC5, RC6.

Asymmetric Encryption- C'est la cryptographie à clé publique qui utilise une paire de clés pour le cryptage: une clé publique pour crypter les données et une clé privée pour le décryptage. La clé publique est publiée pour les personnes tout en gardant la clé privée secrète. Par exemple, RSA, Digital Signature Algorithm (DSA), Elgamal.

Hashing- Le hachage est un cryptage ONE-WAY, qui crée une sortie brouillée qui ne peut pas être inversée ou du moins ne peut pas être inversée facilement. Par exemple, l'algorithme MD5. Il est utilisé pour créer des certificats numériques, des signatures numériques, le stockage des mots de passe, la vérification des communications, etc.

La politique de même origine (SOP) est un concept important dans le modèle de sécurité des applications Web.

Qu'est-ce que la politique de même origine?

Conformément à cette politique, il autorise l'exécution de scripts sur des pages provenant du même site qui peuvent être une combinaison des éléments suivants:

  • Domain
  • Protocol
  • Port

Exemple

La raison de ce comportement est la sécurité. Si vous avez try.com dans une fenêtre et gmail.com dans une autre fenêtre, vous ne voulez PAS qu'un script de try.com accède ou modifie le contenu de gmail.com ou exécute des actions dans le contexte de gmail en votre nom.

Vous trouverez ci-dessous des pages Web de la même origine. Comme expliqué précédemment, la même origine prend en compte le domaine / protocole / port.

  • http://website.com
  • http://website.com/
  • http://website.com/my/contact.html

Vous trouverez ci-dessous des pages Web d'une origine différente.

  • http://www.site.co.uk (un autre domaine)
  • http://site.org (un autre domaine)
  • https://site.com (un autre protocole)
  • http://site.com:8080 (un autre port)

Exceptions de politique de même origine pour IE

Internet Explorer a deux exceptions majeures aux SOP.

  • Le premier est lié aux «zones de confiance». Si les deux domaines se trouvent dans une zone hautement fiable, la stratégie de même origine ne s'applique pas complètement.

  • La deuxième exception dans IE est liée au port. IE n'inclut pas le port dans la politique de même origine, par conséquent, les sites http://website.com et http://wesite.com:4444 sont considérés comme ayant la même origine et aucune restriction n'est appliquée.

Qu'est-ce qu'un cookie?

Un cookie est une petite information envoyée par un serveur Web pour stocker sur un navigateur Web afin qu'elle puisse être lue ultérieurement par le navigateur. De cette façon, le navigateur se souvient de certaines informations personnelles spécifiques. Si un pirate informatique récupère les informations du cookie, cela peut entraîner des problèmes de sécurité.

Propriétés des cookies

Voici quelques propriétés importantes des cookies -

  • Il s'agit généralement de petits fichiers texte, dotés d'étiquettes d'identification stockées dans le répertoire du navigateur de votre ordinateur.

  • Ils sont utilisés par les développeurs Web pour aider les utilisateurs à naviguer efficacement sur leurs sites Web et à exécuter certaines fonctions.

  • Lorsque l'utilisateur navigue à nouveau sur le même site Web, les données stockées dans le cookie sont renvoyées au serveur Web pour informer le site Web des activités précédentes de l'utilisateur.

  • Les cookies sont inévitables pour les sites Web qui ont d'énormes bases de données, ont besoin de connexions, ont des thèmes personnalisables.

Contenu des cookies

Le cookie contient les informations suivantes -

  • Le nom du serveur à partir duquel le cookie a été envoyé.
  • La durée de vie du cookie.
  • Une valeur - généralement un numéro unique généré de manière aléatoire.

Types de cookies

  • Session Cookies- Ces cookies sont temporaires et sont effacés lorsque l'utilisateur ferme le navigateur. Même si l'utilisateur se connecte à nouveau, un nouveau cookie pour cette session est créé.

  • Persistent cookies- Ces cookies restent sur le disque dur à moins que l'utilisateur ne les efface ou qu'ils expirent. L'expiration du cookie dépend de sa durée.

Test des cookies

Voici les moyens de tester les cookies -

  • Disabling Cookies- En tant que testeur, nous devons vérifier l'accès au site Internet après avoir désactivé les cookies et vérifier si les pages fonctionnent correctement. Accédez à toutes les pages du site Web et surveillez les plantages d'applications. Il est également nécessaire d'informer l'utilisateur que des cookies sont nécessaires pour utiliser le site.

  • Corrupting Cookies- Un autre test à effectuer consiste à corrompre les cookies. Pour faire de même, il faut trouver l'emplacement du cookie du site et le modifier manuellement avec des données fausses / invalides qui peuvent être utilisées pour accéder aux informations internes du domaine qui à son tour peuvent ensuite être utilisées pour pirater le site.

  • Removing Cookies - Supprimez tous les cookies du site et vérifiez comment le site y réagit.

  • Cross-Browser Compatibility - Il est également important de vérifier que les cookies sont correctement écrits sur tous les navigateurs pris en charge à partir de n'importe quelle page qui écrit des cookies.

  • Editing Cookies- Si l'application utilise des cookies pour stocker les informations de connexion, en tant que testeur, nous devrions essayer de changer l'utilisateur dans le cookie ou la barre d'adresse pour un autre utilisateur valide. La modification du cookie ne doit pas vous permettre de vous connecter à un autre compte utilisateur.

Affichage et modification des cookies

Les navigateurs modernes prennent en charge l'affichage / la modification des cookies dans le navigateur lui-même. Il existe des plugins pour mozilla / chrome avec lesquels nous pouvons effectuer l'édition avec succès.

  • Modifier le plugin des cookies pour Firefox

  • Modifier ce plugin de cookie pour Chrome

Les étapes doivent être effectuées pour modifier un cookie -

  • Téléchargez le plugin pour Chrome à partir d' ici

  • Modifiez la valeur du cookie simplement en accédant au plugin 'modifier ce cookie' à partir de chrome comme indiqué ci-dessous.

Il existe différentes méthodologies / approches que nous pouvons utiliser comme référence pour effectuer une attaque.

Application Web - Méthodologies de PenTesting

On peut prendre en compte les standards suivants lors du développement d'un modèle d'attaque.

Parmi la liste suivante, l'OWASP est le plus actif et il y a un certain nombre de contributeurs. Nous nous concentrerons sur les techniques OWASP que chaque équipe de développement prend en compte avant de concevoir une application Web.

  • PTES - Norme d'exécution des tests de pénétration

  • OSSTMM - Manuel de méthodologie de test de sécurité Open Source

  • Techniques de test OWASP - Open Web Application Security Protocol

Top 10 de l'OWASP

L'équipe Open Web Application Security Protocol a publié les 10 principales vulnérabilités les plus répandues sur le Web ces dernières années. Vous trouverez ci-dessous la liste des failles de sécurité les plus courantes dans une application Web.

Application - Pratique

Afin de comprendre chacune des techniques, travaillons avec un exemple d'application. Nous allons effectuer l'attaque sur «WebGoat», l'application J2EE qui est développée explicitement avec des failles de sécurité à des fins d'apprentissage.

Les détails complets sur le projet webgoat peuvent être trouvés https://www.owasp.org/index.php/Category:OWASP_WebGoat_Project. Pour télécharger l'application WebGoat, accédez àhttps://github.com/WebGoat/WebGoat/wiki/Installation-(WebGoat-6.0) et allez à la section des téléchargements.

Pour installer l'application téléchargée, assurez-vous d'abord qu'aucune application ne s'exécute sur le port 8080. Elle peut être installée simplement en utilisant une seule commande - java -jar WebGoat-6.0.1-war-exec.jar. Pour plus de détails, visitez Installation de WebGoat

Après l'installation, nous devrions pouvoir accéder à l'application en accédant à http://localhost:8080/WebGoat/attack et la page serait affichée comme indiqué ci-dessous.

Nous pouvons utiliser les informations d'identification de l'invité ou de l'administrateur telles qu'affichées dans la page de connexion.

Proxy Web

Afin d'intercepter le trafic entre le client (navigateur) et le serveur (système où l'application Webgoat est hébergée dans notre cas), nous devons utiliser un proxy Web. Nous utiliserons Burp Proxy qui peut être téléchargé depuishttps://portswigger.net/burp/download.html

Il suffit de télécharger la version gratuite de burp suite comme indiqué ci-dessous.

Configurer Burp Suite

Burp Suite est un proxy Web qui peut intercepter chaque paquet d'informations envoyé et reçu par le navigateur et le serveur Web. Cela nous aide à modifier le contenu avant que le client envoie les informations au serveur Web.

Step 1- L'application est installée sur le port 8080 et Burp est installé sur le port 8181 comme indiqué ci-dessous. Lancez Burp suite et effectuez les réglages suivants afin de l'amener dans le port 8181 comme indiqué ci-dessous.

Step 2- Nous devons nous assurer que le Burp écoute le port # 8080 où l'application est installée afin que Burp suite puisse intercepter le trafic. Ces réglages doivent être effectués sur l'onglet Scope de Burp Suite comme indiqué ci-dessous.

Step 3- Ensuite, configurez les paramètres proxy de votre navigateur pour écouter le port 8181 (port Burp Suite). Ainsi, nous avons configuré le proxy Web pour intercepter le trafic entre le client (navigateur) et le serveur (serveur Web) comme indiqué ci-dessous -

Step 4 - L'instantané de la configuration est illustré ci-dessous à l'aide d'un simple diagramme de flux de travail comme indiqué ci-dessous

La technique d'injection consiste à injecter une requête SQL ou une commande en utilisant les champs de saisie de l'application.

Application Web - Injection

Une injection SQL réussie peut lire, modifier des données sensibles de la base de données et peut également supprimer des données d'une base de données. Il permet également au pirate d'effectuer des opérations administratives sur la base de données telles que l'arrêt du SGBD / suppression de bases de données.

Comprenons les agents de menace, les vecteurs d'attaque, la faiblesse de la sécurité, l'impact technique et les impacts commerciaux de cette faille à l'aide d'un diagramme simple.

Exemples

L'application utilise des données non approuvées dans la construction de l'appel SQL vulnérable suivant -

String query = "SELECT * FROM EMP WHERE EMPID = '" + request.getParameter("id") + "'";

Mains sur

Step 1 - Accédez à la zone d'injection SQL de l'application comme indiqué ci-dessous.

Step 2- Comme indiqué dans l'exercice, nous utilisons une injection String SQL pour contourner l'authentification. Utilisez l'injection SQL pour vous connecter en tant que patron («Neville») sans utiliser le mot de passe correct. Vérifiez que le profil de Neville peut être consulté et que toutes les fonctions sont disponibles (y compris Rechercher, Créer et Supprimer).

Step 3 - Nous allons injecter un SQL tel que nous pouvons contourner le mot de passe en envoyant le paramètre comme 'a' = 'a' ou 1 = 1

Step 4 - Après exploitation, nous pouvons nous connecter en tant que Neville qui est l'administrateur comme indiqué ci-dessous.

Empêcher l'injection SQL

Il existe de nombreuses façons d'empêcher l'injection SQL. Lorsque les développeurs écrivent le code, ils doivent s'assurer de gérer les caractères spéciaux en conséquence. Il existe des feuilles de triche / techniques de prévention disponibles auprès de l'OWASP, ce qui est certainement un guide pour les développeurs.

  • Utilisation de requêtes paramétrées
  • Échapper à toutes les entrées fournies par l'utilisateur
  • Activer le moindre privilège pour la base de données pour les utilisateurs finaux

Lorsque les fonctions d'authentification liées à l'application ne sont pas correctement implémentées, cela permet aux pirates de compromettre les mots de passe ou les identifiants de session ou d'exploiter d'autres failles d'implémentation en utilisant les informations d'identification d'autres utilisateurs.

Comprenons les agents de menace, les vecteurs d'attaque, la faiblesse de la sécurité, l'impact technique et les impacts commerciaux de cette faille à l'aide d'un diagramme simple.

Exemple

An e-commerce application supports URL rewriting, putting session IDs in the URL −

http://example.com/sale/saleitems/jsessionid=2P0OC2JSNDLPSKHCJUN2JV/?item=laptop

Un utilisateur authentifié du site transmet l'URL à ses amis pour connaître les ventes à prix réduit. Il envoie par e-mail le lien ci-dessus sans savoir que l'utilisateur donne également les identifiants de session. Lorsque ses amis utilisent le lien, ils utilisent sa session et sa carte de crédit.

Mains sur

Step 1- Connectez-vous à Webgoat et accédez à la section «Défauts de gestion de session». Contournons l'authentification en usurpant le cookie. Voici un aperçu du scénario.

Step 2 - Lorsque nous nous connectons en utilisant les identifiants webgoat / webgoat, nous trouvons de Burp Suite que l'ID JSESSION est C8F3177CCAFF380441ABF71090748F2E tandis que AuthCookie = 65432ubphcfx lors de l'authentification réussie.

Step 3 - Lorsque nous nous connectons en utilisant l'aspect / l'aspect des informations d'identification, nous trouvons de Burp Suite que l'ID JSESSION est C8F3177CCAFF380441ABF71090748F2E tandis que l'AuthCookie = 65432udfqtb après une authentification réussie.

Step 4- Nous devons maintenant analyser les modèles AuthCookie. La première moitié «65432» est commune aux deux authentifications. Par conséquent, nous sommes maintenant intéressés par l'analyse de la dernière partie des valeurs d'authcookie telles que - ubphcfx pour l'utilisateur webgoat et udfqtb pour l'utilisateur d'aspect respectivement.

Step 5- Si nous examinons en profondeur les valeurs d'AuthCookie, la dernière partie a la même longueur que celle du nom d'utilisateur. Il est donc évident que le nom d'utilisateur est utilisé avec une méthode de cryptage. Après des essais et des erreurs / mécanismes de force brute, nous constatons qu'après avoir inversé le nom d'utilisateur, webgoat; nous nous retrouvons avec taogbew, puis le caractère alphabétique avant est ce qui est utilisé comme AuthCookie. c'est-à-dire ubphcfx.

Step 6- Si nous transmettons cette valeur de cookie et voyons ce qui se passe. Lors de l'authentification en tant que webgoat utilisateur, modifiez la valeur AuthCookie pour se moquer de l'utilisateur Alice en recherchant l'AuthCookie pour le même en exécutant les étapes 4 et 5.

Mécanismes de prévention

  • Développer une authentification forte et des contrôles de gestion de session afin qu'il réponde à toutes les exigences d'authentification et de gestion de session définies dans la norme de vérification de la sécurité des applications de l'OWASP.

  • Les développeurs doivent s'assurer d'éviter les failles XSS qui peuvent être utilisées pour voler des identifiants de session.

Le Cross-site Scripting (XSS) se produit chaque fois qu'une application prend des données non approuvées et les envoie au client (navigateur) sans validation. Cela permet aux attaquants d'exécuter des scripts malveillants dans le navigateur de la victime, ce qui peut entraîner le piratage des sessions utilisateur, la dégradation de sites Web ou la redirection de l'utilisateur vers des sites malveillants.

Comprenons les agents de menace, les vecteurs d'attaque, la faiblesse de la sécurité, l'impact technique et les impacts commerciaux de cette faille à l'aide d'un diagramme simple.

Types de XSS

  • Stored XSS - Le XSS stocké, également connu sous le nom de XSS persistant, se produit lorsque l'entrée de l'utilisateur est stockée sur le serveur cible, comme la base de données / le forum de message / le champ de commentaire, etc.

  • Reflected XSS - Le XSS reflété également connu sous le nom de XSS non persistant se produit lorsque l'entrée de l'utilisateur est immédiatement renvoyée par une application Web dans un message d'erreur / résultat de recherche ou l'entrée fournie par l'utilisateur dans le cadre de la demande et sans stocker en permanence les données fournies par l'utilisateur.

  • DOM Based XSS - DOM Based XSS est une forme de XSS lorsque la source des données est dans le DOM, le puits est également dans le DOM et le flux de données ne quitte jamais le navigateur.

Exemple

L'application utilise des données non approuvées dans la construction sans validation. Les caractères spéciaux doivent être échappés.

http://www.webpage.org/task/Rule1?query=try

L'attaquant modifie le paramètre de requête dans son navigateur pour -

http://www.webpage.org/task/Rule1?query=<h3>Hello from XSS"</h3>

Mains sur

Step 1- Connectez-vous à Webgoat et accédez à la section Cross-site scripting (XSS). Exécutons une attaque XSS (Stored Cross-site Scripting). Voici un aperçu du scénario.

Step 2- Selon le scénario, connectons-nous en tant que Tom avec le mot de passe «tom» comme mentionné dans le scénario lui-même. Cliquez sur «afficher le profil» et passez en mode édition. Puisque Tom est l'attaquant, injectons un script Java dans ces zones d'édition.

<script> 
   alert("HACKED")
</script>

Step 3 - Dès que la mise à jour est terminée, tom reçoit une boîte d'alerte avec le message "piraté" ce qui signifie que l'application est vulnérable.

Step 4 - Maintenant, selon le scénario, nous devons nous connecter en tant que jerry (HR) et vérifier si jerry est affecté par le script injecté.

Step 5 - Après vous être connecté en tant que Jerry, sélectionnez «Tom» et cliquez sur «Voir le profil» comme indiqué ci-dessous.

Lors de la visualisation du profil de Tom à partir du compte de Jerry, il peut obtenir la même boîte de message.

Step 6 - Cette boîte de message n'est qu'un exemple, mais l'attaquant réel peut faire bien plus que simplement afficher une boîte de message.

Mécanismes préventifs

  • Les développeurs doivent s'assurer qu'ils échappent à toutes les données non approuvées en fonction du contexte HTML tel que le corps, l'attribut, le JavaScript, le CSS ou l'URL dans lequel les données sont placées.

  • Pour les applications qui nécessitent des caractères spéciaux en entrée, des mécanismes de validation robustes doivent être en place avant de les accepter comme entrées valides.

Une référence directe à un objet est susceptible de se produire lorsqu'un développeur expose une référence à un objet d'implémentation interne, tel qu'un fichier, un répertoire ou une clé de base de données sans aucun mécanisme de validation qui permet aux attaquants de manipuler ces références pour accéder à des données non autorisées.

Comprenons les agents de menace, les vecteurs d'attaque, la faiblesse de la sécurité, l'impact technique et les impacts commerciaux de cette faille à l'aide d'un diagramme simple.

Exemple

L'application utilise des données non vérifiées dans un appel SQL qui accède aux informations de compte.

String sqlquery = "SELECT * FROM useraccounts WHERE account = ?";
PreparedStatement st = connection.prepareStatement(sqlquery, ??);
st.setString( 1, request.getParameter("acct"));
ResultSet results = st.executeQuery( );

L'attaquant modifie le paramètre de requête dans son navigateur pour qu'il pointe vers Admin.

http://webapp.com/app/accountInfo?acct=admin

Mains sur

Step 1- Connectez-vous à Webgoat et accédez à la section des failles de contrôle d'accès. Le but est de récupérer le fichier tomcat-users.xml en accédant au chemin où il se trouve. Voici un aperçu du scénario.

Step 2 - Le chemin du fichier est affiché dans le champ 'le répertoire courant est' - C: \ Users \ userName $ \. Extract \ webapps \ WebGoat \ leçon_plans \ fr et nous savons également que le fichier tomcat-users.xml est conservé sous C: \ xampp \ tomcat \ conf

Step 3- Nous devons parcourir tout le chemin hors du répertoire actuel et naviguer à partir de C: \ Drive. Nous pouvons faire de même en interceptant le trafic à l'aide de Burp Suite.

Step 4 - Si la tentative réussit, il affiche le fichier tomcat-users.xml avec le message "Félicitations. Vous avez terminé cette leçon avec succès."

Mécanismes préventifs

Les développeurs peuvent utiliser les ressources / points suivants comme guide pour éviter une référence directe non sécurisée aux objets pendant la phase de développement elle-même.

  • Les développeurs ne doivent utiliser qu'un seul utilisateur ou une seule session pour les références indirectes aux objets.

  • Il est également recommandé de vérifier l'accès avant d'utiliser une référence d'objet directe à partir d'une source non approuvée.

Une mauvaise configuration de sécurité survient lorsque les paramètres de sécurité sont définis, implémentés et maintenus par défaut. Une bonne sécurité nécessite une configuration sécurisée définie et déployée pour l'application, le serveur Web, le serveur de base de données et la plate-forme. Il est tout aussi important d'avoir le logiciel à jour.

Exemple

Quelques exemples classiques de mauvaise configuration de sécurité sont donnés -

  • Si la liste des répertoires n'est pas désactivée sur le serveur et si l'attaquant découvre la même chose, l'attaquant peut simplement lister les répertoires pour trouver n'importe quel fichier et l'exécuter. Il est également possible d'obtenir la base de code réelle qui contient tout votre code personnalisé, puis de trouver de sérieuses failles dans l'application.

  • La configuration du serveur d'applications permet de renvoyer les traces de pile aux utilisateurs, exposant potentiellement des failles sous-jacentes. Les attaquants récupèrent les informations supplémentaires fournies par les messages d'erreur et qui leur suffisent à pénétrer.

  • Les serveurs d'applications sont généralement fournis avec des exemples d'applications qui ne sont pas bien sécurisées. S'il n'est pas supprimé du serveur de production, cela compromettrait votre serveur.

Mains sur

Step 1- Lancez Webgoat et accédez à la section de configuration non sécurisée et essayons de résoudre ce défi. Un instantané de la même chose est fourni ci-dessous -

Step 2- Nous pouvons essayer autant d'options que nous pouvons penser. Tout ce dont nous avons besoin pour trouver l'URL du fichier de configuration et nous savons que les développeurs suivent une sorte de convention de dénomination pour les fichiers de configuration. Cela peut être tout ce qui est listé ci-dessous. Cela se fait généralement par la technique de la force BRUTE.

  • web.config
  • config
  • appname.config
  • conf

Step 3 - En essayant diverses options, nous constatons que 'http://localhost:8080/WebGoat/conf' est réussi. La page suivante s'affiche si la tentative réussit -

Mécanismes préventifs

  • Tous les environnements tels que les environnements de développement, d'assurance qualité et de production doivent être configurés de manière identique en utilisant différents mots de passe utilisés dans chaque environnement qui ne peuvent pas être piratés facilement.

  • Assurez-vous qu'une architecture d'application solide est adoptée, offrant une séparation efficace et sécurisée entre les composants.

  • Il peut également minimiser la possibilité de cette attaque en exécutant des analyses automatisées et en effectuant des audits périodiquement.

Comme les applications en ligne continuent d'inonder Internet de jour en jour, toutes les applications ne sont pas sécurisées. De nombreuses applications Web ne protègent pas correctement les données utilisateur sensibles telles que les informations de carte de crédit / les informations de compte bancaire / les informations d'authentification. Les pirates informatiques pourraient finir par voler ces données faiblement protégées pour mener une fraude par carte de crédit, un vol d'identité ou d'autres crimes.

Comprenons les agents de menace, les vecteurs d'attaque, la faiblesse de la sécurité, l'impact technique et les impacts commerciaux de cette faille à l'aide d'un diagramme simple.

Exemple

Certains des exemples classiques de mauvaise configuration de la sécurité sont comme donnés -

  • Un site n'utilise tout simplement pas SSL pour toutes les pages authentifiées. Cela permet à un attaquant de surveiller le trafic réseau et de voler le cookie de session de l'utilisateur pour détourner la session des utilisateurs ou accéder à leurs données privées.

  • Une application stocke les numéros de carte de crédit dans un format crypté dans une base de données. Lors de la récupération, ils sont décryptés, ce qui permet au pirate d'effectuer une attaque par injection SQL pour récupérer toutes les informations sensibles dans un texte clair. Cela peut être évité en cryptant les numéros de carte de crédit à l'aide d'une clé publique et en autorisant les applications dorsales à les décrypter avec la clé privée.

Mains sur

Step 1- Lancez WebGoat et accédez à la section "Stockage non sécurisé". Un instantané de la même chose est affiché ci-dessous.

Step 2- Entrez le nom d'utilisateur et le mot de passe. Il est temps d'apprendre les différents types de méthodologies d'encodage et de cryptage dont nous avons parlé précédemment.

Mécanismes préventifs

  • Il est conseillé de ne pas stocker inutilement des données sensibles et de les supprimer dès que possible si elles ne sont plus nécessaires.

  • Il est important de nous assurer que nous incorporons des algorithmes de chiffrement solides et standard et qu'une gestion des clés appropriée est en place.

  • Cela peut également être évité en désactivant la saisie semi-automatique sur les formulaires qui collectent des données sensibles telles que le mot de passe et en désactivant la mise en cache pour les pages contenant des données sensibles.

La plupart des applications Web vérifient les droits d'accès au niveau de la fonction avant de rendre cette fonctionnalité accessible à l'utilisateur. Cependant, si les mêmes contrôles de contrôle d'accès ne sont pas effectués sur le serveur, les pirates peuvent pénétrer dans l'application sans autorisation appropriée.

Comprenons les agents de menace, les vecteurs d'attaque, la faiblesse de la sécurité, l'impact technique et les impacts commerciaux de cette faille à l'aide d'un diagramme simple.

Exemple

Voici un exemple classique de contrôle d'accès au niveau de fonction manquant -

Le hacker force simplement les URL cibles. L'accès administrateur nécessite généralement une authentification, cependant, si l'accès à l'application n'est pas vérifié, un utilisateur non authentifié peut accéder à la page d'administration.

' Below URL might be accessible to an authenticated user
http://website.com/app/standarduserpage

' A NON Admin user is able to access admin page without authorization.
http://website.com/app/admin_page

Mains sur

Step 1 - Laissez-nous vous connecter en tant que gestionnaire de compte en parcourant d'abord la liste des utilisateurs et leurs privilèges d'accès.

Step 2 - En essayant diverses combinaisons, nous pouvons découvrir que Larry a accès au gestionnaire de compte de ressources.

Mécanismes préventifs

  • Le mécanisme d'authentification doit refuser tous les accès par défaut et fournir l'accès à des rôles spécifiques pour chaque fonction.

  • Dans une application basée sur un flux de travail, vérifiez l'état des utilisateurs avant de leur permettre d'accéder à des ressources.

Une attaque CSRF force un utilisateur authentifié (victime) à envoyer une requête HTTP falsifiée, y compris le cookie de session de la victime à une application Web vulnérable, ce qui permet à l'attaquant de forcer le navigateur de la victime à générer une requête de telle sorte que l'application vulnérable perçoit comme des requêtes légitimes de la victime.

Comprenons les agents de menace, les vecteurs d'attaque, la faiblesse de la sécurité, l'impact technique et les impacts commerciaux de cette faille à l'aide d'un diagramme simple.

Exemple

Voici un exemple classique de CSRF -

Step 1 - Disons que l'application vulnérable envoie une demande de changement d'état sous forme de texte brut sans aucun cryptage.

http://bankx.com/app?action=transferFund&amount=3500&destinationAccount=4673243243

Step 2 - Maintenant, le pirate construit une demande qui transfère de l'argent du compte de la victime vers le compte de l'attaquant en incorporant la demande dans une image qui est stockée sur divers sites sous le contrôle de l'attaquant -

<img src = "http://bankx.com/app?action=transferFunds&amount=14000&destinationAccount=attackersAcct#" 
   width = "0" height = "0" />

Mains sur

Step 1- Réalisons une falsification CSRF en intégrant un script Java dans une image. L'instantané du problème est répertorié ci-dessous.

Step 2 - Maintenant, nous devons simuler le transfert dans une image 1x1 et faire en sorte que la victime clique dessus.

Step 3 - Lors de la soumission du message, le message s'affiche comme indiqué ci-dessous.

Step 4- Maintenant, si la victime clique sur l'URL suivante, le transfert est exécuté, ce qui peut être trouvé en interceptant l'action de l'utilisateur à l'aide de burp suite. Nous pouvons voir le transfert en le repérant dans Get message comme indiqué ci-dessous -

Step 5 - Maintenant, en cliquant sur Actualiser, la marque de fin de leçon s'affiche.

Mécanismes préventifs

  • CSRF peut être évité en créant un jeton unique dans un champ caché qui serait envoyé dans le corps de la requête HTTP plutôt que dans une URL, qui est plus sujette à l'exposition.

  • Forcer l'utilisateur à s'authentifier de nouveau ou prouver qu'il est un utilisateur afin de protéger CSRF. Par exemple, CAPTCHA.

Ce type de menace se produit lorsque les composants tels que les bibliothèques et les frameworks utilisés dans l'application s'exécutent presque toujours avec tous les privilèges. Si un composant vulnérable est exploité, cela facilite le travail du pirate en provoquant une grave perte de données ou une prise de contrôle du serveur.

Comprenons les agents de menace, les vecteurs d'attaque, la faiblesse de la sécurité, l'impact technique et les impacts commerciaux de cette faille à l'aide d'un diagramme simple.

Exemple

Les exemples suivants illustrent l'utilisation de composants présentant des vulnérabilités connues -

  • Les attaquants peuvent invoquer n'importe quel service Web avec une autorisation complète en ne fournissant pas de jeton d'identité.

  • L'exécution de code à distance avec la vulnérabilité d'injection de langage d'expression est introduite via Spring Framework pour les applications Java.

Mécanismes préventifs

  • Identifiez tous les composants et les versions qui sont utilisés dans les applications Web, pas uniquement limités aux bases de données / frameworks.

  • Gardez à jour tous les composants tels que les bases de données publiques, les listes de diffusion de projets, etc.

  • Ajoutez des wrappers de sécurité autour des composants vulnérables par nature.

La plupart des applications Web sur Internet redirigent et redirigent fréquemment les utilisateurs vers d'autres pages ou d'autres sites Web externes. Cependant, sans valider la crédibilité de ces pages, les pirates peuvent rediriger les victimes vers des sites de phishing ou de logiciels malveillants, ou utiliser des renvois pour accéder à des pages non autorisées.

Comprenons les agents de menace, les vecteurs d'attaque, la faiblesse de la sécurité, l'impact technique et les impacts commerciaux de cette faille à l'aide d'un diagramme simple.

Exemple

Quelques exemples classiques de redirections et de transferts non validés sont comme donnés -

  • Disons que l'application a une page - redirect.jsp, qui prend un paramètre redirectrul . Le pirate ajoute une URL malveillante qui redirige les utilisateurs qui effectuent du phishing / installent des logiciels malveillants.

http://www.mywebapp.com/redirect.jsp?redirectrul=hacker.com
  • Toutes les applications Web utilisées pour rediriger les utilisateurs vers différentes parties du site. Afin de réaliser la même chose, certaines pages utilisent un paramètre pour indiquer où l'utilisateur doit être redirigé si une opération réussit. L'attaquant crée une URL qui passe la vérification de contrôle d'accès de l'application, puis transmet l'attaquant à une fonctionnalité administrative pour laquelle l'attaquant n'a pas accès.

http://www.mywebapp.com/checkstatus.jsp?fwd=appadmin.jsp

Mécanismes préventifs

  • Il vaut mieux éviter d'utiliser les redirections et les transferts.

  • Si cela est inévitable, alors cela devrait être fait sans impliquer les paramètres utilisateur dans la redirection de la destination.

Le Javascript asynchrone et XML (AJAX) est l'une des dernières techniques utilisées pour développer des applications Web afin de donner une expérience utilisateur riche. Puisqu'il s'agit d'une nouvelle technologie, il existe de nombreux problèmes de sécurité qui doivent encore être résolus et voici les quelques problèmes de sécurité dans AJAX.

  • La surface d'attaque est plus car il y a plus d'entrées à sécuriser.

  • Il expose également les fonctions internes des applications.

  • Échec de la protection des informations et des sessions d'authentification.

  • Il y a une ligne très étroite entre côté client et côté serveur, d'où la possibilité de commettre des erreurs de sécurité.

Exemple

Voici un exemple pour AJAX Security -

En 2006, un ver a infecté le service de messagerie Yahoo en utilisant XSS et AJAX qui a profité d'une vulnérabilité dans la gestion des événements onload de Yahoo Mail. Lorsqu'un e-mail infecté était ouvert, le ver exécutait son JavaScript, en envoyant une copie à tous les contacts Yahoo de l'utilisateur infecté.

Mains sur

Step 1- Nous devons essayer d'ajouter plus de récompenses à votre ensemble de récompenses autorisé à l'aide de l'injection XML. Voici un aperçu du scénario.

Step 2- Assurez-vous que nous interceptons à la fois la demande et la réponse en utilisant Burp Suite. Paramètres identiques à ceux indiqués ci-dessous.

Step 3- Saisissez le numéro de compte comme indiqué dans le scénario. Nous pourrons obtenir une liste de toutes les récompenses auxquelles nous sommes éligibles. Nous sommes éligibles à 3 récompenses sur 5.

Step 4- Maintenant, cliquons sur «Soumettre» et voyons ce que nous obtenons dans le XML de réponse. Comme indiqué ci-dessous, les trois récompenses auxquelles nous sommes éligibles nous sont transmises au format XML.

Step 5 - Maintenant, éditons ces XML et ajoutons également les deux autres récompenses.

Step 6- Maintenant, toutes les récompenses seraient affichées à l'utilisateur pour qu'il puisse les sélectionner. Sélectionnez ceux que nous avons ajoutés et cliquez sur «Soumettre».

Step 7 - Le message suivant apparaît disant: "* Félicitations. Vous avez terminé cette leçon avec succès."

Mécanismes préventifs

Côté client -

  • Utilisez .innerText au lieu de .innerHtml.
  • N'utilisez pas eval.
  • Ne vous fiez pas à la logique client pour la sécurité.
  • Évitez d'écrire du code de sérialisation.
  • Évitez de créer du XML dynamiquement.
  • Ne transmettez jamais de secrets au client.
  • N'effectuez pas de chiffrement dans le code côté client.
  • N'exécutez pas de logique impactant la sécurité côté client.

Côté serveur -

  • Utilisez la protection CSRF.
  • Évitez d'écrire du code de sérialisation.
  • Les services peuvent être appelés directement par les utilisateurs.
  • Évitez de construire du XML à la main, utilisez le framework.
  • Évitez de créer JSON à la main, utilisez un framework existant.

Dans les applications Web modernes, l'utilisation des services Web est inévitable et ils sont également sujets aux attaques. Étant donné que les services Web demandent à être récupérés auprès de plusieurs sites Web, les développeurs doivent prendre quelques mesures supplémentaires afin d'éviter tout type de pénétration par des pirates.

Mains sur

Step 1- Accédez à la zone des services Web de Webgoat et accédez à Analyse WSDL. Nous devons maintenant obtenir les détails de la carte de crédit d'un autre numéro de compte. Un instantané du scénario est indiqué ci-dessous.

Step 2 - Si nous sélectionnons le prénom, l'appel de la fonction 'getFirstName' est effectué via la requête SOAP xml.

Step 3- En ouvrant le WSDL, nous pouvons voir qu'il existe une méthode pour récupérer les informations de carte de crédit ainsi que «getCreditCard». Maintenant, laissez-nous trafiquer les entrées en utilisant la suite Burp comme indiqué ci-dessous -

Step 4 - Modifions maintenant les entrées en utilisant la suite Burp comme indiqué ci-dessous -

Step 5 - Nous pouvons obtenir les informations de carte de crédit d'autres utilisateurs.

Mécanismes préventifs

  • Étant donné que les messages SOAP sont basés sur XML, toutes les informations d'identification transmises doivent être converties au format texte. Il faut donc être très prudent en transmettant les informations sensibles qui doivent toujours être cryptées.

  • Protéger l'intégrité des messages en mettant en œuvre des mécanismes tels que la somme de contrôle appliquée pour garantir l'intégrité du paquet.

  • Protection de la confidentialité des messages - Un cryptage asymétrique est appliqué pour protéger les clés de session symétriques, qui dans de nombreuses implémentations sont valides pour une seule communication et sont ensuite rejetées.

Un débordement de tampon se produit lorsqu'un programme tente de stocker plus de données dans une zone de stockage de données temporaire (tampon) qu'il ne devait en contenir. Puisque les tampons sont créés pour contenir une quantité finie de données, les informations supplémentaires peuvent déborder dans des tampons adjacents, corrompant ainsi les données valides qui y sont conservées.

Exemple

Voici un exemple classique de buffer overflow. Il illustre un simple dépassement de mémoire tampon qui est provoqué par le premier scénario dans lequel s'appuie sur des données externes pour contrôler son comportement. Il n'y a aucun moyen de limiter la quantité de données que l'utilisateur a entrées et le comportement du programme dépend du nombre de caractères que l'utilisateur a mis à l'intérieur.

...
   char bufr[BUFSIZE]; 
   gets(bufr);
   ...

Mains sur

Step 1- Nous devons nous connecter avec le nom et le numéro de chambre pour accéder à Internet. Voici l'instantané du scénario.

Step 2 - Nous allons également activer "Afficher les champs de formulaire cachés" dans Burp Suite comme indiqué ci-dessous -

Step 3- Maintenant, nous envoyons une entrée dans le champ nom et numéro de chambre. Nous essayons également d'injecter un nombre assez important dans le champ du numéro de chambre.

Step 4- Les champs masqués sont affichés comme indiqué ci-dessous. Nous cliquons sur accepter les conditions.

Step 5 - L'attaque est réussie de telle sorte qu'à la suite d'un dépassement de mémoire tampon, elle a commencé à lire les emplacements mémoire adjacents et affichée à l'utilisateur comme indiqué ci-dessous.

Step 6- Maintenant, connectons-nous en utilisant les données affichées. Après la journalisation, le message suivant s'affiche -

Mécanismes préventifs

  • Révision du code
  • Formation développeur
  • Outils du compilateur
  • Développer des fonctions Safe
  • Numérisation périodique

L'attaque par déni de service (DoS) est une tentative par des pirates de rendre une ressource réseau indisponible. Il interrompt généralement l'hôte, temporairement ou indéfiniment, qui est connecté à Internet. Ces attaques ciblent généralement des services hébergés sur des serveurs Web critiques tels que les banques, les passerelles de paiement par carte de crédit.

Symptômes du DoS

  • Performances réseau inhabituellement lentes.
  • Indisponibilité d'un site Web particulier.
  • Incapacité d'accéder à un site Web.
  • Augmentation spectaculaire du nombre de spams reçus.
  • Refus à long terme d'accès au Web ou à tout service Internet.
  • Indisponibilité d'un site Web particulier.

Mains sur

Step 1- Lancez WebGoat et accédez à la section «Déni de service». L'image instantanée du scénario est donnée ci-dessous. Nous devons nous y connecter plusieurs fois en enfreignant la taille maximale du pool de threads DB.

Step 2- Nous devons d'abord obtenir la liste des connexions valides. Nous utilisons l'injection SQL dans ce cas.

Step 3 - Si la tentative réussit, il affiche toutes les informations d'identification valides à l'utilisateur.

Step 4- Connectez-vous maintenant avec chacun de ces utilisateurs dans au moins 3 sessions différentes afin de réussir l'attaque DoS. Comme nous savons que la connexion DB ne peut gérer que deux threads, en utilisant toutes les connexions, elle créera trois threads qui rendront l'attaque réussie.

Mécanismes préventifs

  • Effectuez des validations approfondies des entrées.

  • Évitez les opérations très gourmandes en CPU.

  • Il est préférable de séparer les disques de données des disques système.

Les développeurs utilisent souvent directement ou concaténent une entrée potentiellement vulnérable avec un fichier ou supposent que les fichiers d'entrée sont authentiques. Lorsque les données ne sont pas vérifiées correctement, cela peut entraîner le traitement ou l'invocation du contenu vulnérable par le serveur Web.

Exemple

Certains des exemples classiques incluent -

  • Téléchargez le fichier .jsp dans l'arborescence Web.
  • Téléchargez .gif à redimensionner.
  • Téléchargez des fichiers volumineux.
  • Téléchargez un fichier contenant des balises.
  • Téléchargez le fichier .exe dans l'arborescence Web.

Mains sur

Step 1- Lancez WebGoat et accédez à la section Exécution de fichiers malveillants. Le cliché du scénario est donné ci-dessous -

Step 2 - Pour terminer cette leçon, nous devons télécharger guest.txt à l'emplacement indiqué ci-dessus.

Step 3- Créons un fichier jsp tel que le fichier guest.txt soit créé lors de l'exécution du jsp. Le nommage du jsp n'a aucun rôle à jouer dans ce contexte car nous exécutons le contenu du fichier jsp.

<HTML> 
   <% java.io.File file = new 
      java.io.File("C:\\Users\\username$\\.extract\\webapps\\WebGoat\\mfe_target\\guest.txt"); 
      file.createNewFile(); %> 
</HTML>

Step 4- Téléchargez maintenant le fichier jsp et copiez l'emplacement du lien de celui-ci après le téléchargement. Le téléchargement attend une image, mais nous téléchargeons un jsp.

Step 5 - En naviguant vers le fichier jsp, il n'y aura aucun message à l'utilisateur.

Step 6 - Maintenant, actualisez la session où vous avez téléchargé le fichier jsp et vous obtiendrez le message disant: "* Félicitations. Vous avez terminé la leçon avec succès".

Mécanismes préventifs

  • Sécurisez les sites Web à l'aide des autorisations de site Web.
  • Adoptez des contre-mesures pour la sécurité des applications Web.
  • Comprendre les comptes d'utilisateurs et de groupes intégrés dans IIS 7.0.

Il existe différents outils disponibles pour effectuer des tests de sécurité d'une application. Il existe peu d'outils capables d'effectuer des tests de sécurité de bout en bout, tandis que certains sont dédiés à la détection d'un type particulier de faille dans le système.

Outils Open Source

Certains outils de test de sécurité open source sont comme donnés -

S.No. Nom de l'outil
1

Zed Attack Proxy

Fournit des scanners automatisés et d'autres outils pour détecter les failles de sécurité.

https://www.owasp.org

2

OWASP WebScarab

Développé en Java pour analyser les requêtes Http et Https.

https://www.owasp.org/index.php

3

OWASP Mantra

Prend en charge le cadre de test de sécurité multilingue

https://www.owasp.org/index.php/OWASP_Mantra_-_Security_Framework

4

Burp Proxy

Outil d'interception et de modification du trafic et fonctionne avec des certificats SSL personnalisés.

https://www.portswigger.net/Burp/

5

Firefox Tamper Data

Utilisez tamperdata pour afficher et modifier les en-têtes HTTP / HTTPS et les paramètres de publication

https://addons.mozilla.org/en-US

6

Firefox Web Developer Tools

L'extension Web Developer ajoute divers outils de développement Web au navigateur.

https://addons.mozilla.org/en-US/firefox

sept

Cookie Editor

Permet à l'utilisateur d'ajouter, supprimer, modifier, rechercher, protéger et bloquer les cookies

https://chrome.google.com/webstore

Ensembles d'outils spécifiques

Les outils suivants peuvent nous aider à repérer un type particulier de vulnérabilité dans le système -

S.No. Lien
1

DOMinator Pro − Testing for DOM XSS

https://dominator.mindedsecurity.com/

2

OWASP SQLiX − SQL Injection

https://www.owasp.org/index.php

3

Sqlninja − SQL Injection

http://sqlninja.sourceforge.net/

4

SQLInjector − SQL Injection

https://sourceforge.net/projects/safe3si/

5

sqlpowerinjector − SQL Injection

http://www.sqlpowerinjector.com/

6

SSL Digger − Testing SSL

https://www.mcafee.com/us/downloads/free-tools

sept

THC-Hydra − Brute Force Password

https://www.thc.org/thc-hydra/

8

Brutus − Brute Force Password

http://www.hoobie.net/brutus/

9

Ncat − Brute Force Password

https://nmap.org/ncat/

dix

OllyDbg − Testing Buffer Overflow

http://www.ollydbg.de/

11

Spike − Testing Buffer Overflow

https://www.immunitysec.com/downloads/SPIKE2.9.tgz

12

Metasploit − Testing Buffer Overflow

https://www.metasploit.com/

Outils de test commerciaux Black Box

Voici quelques-uns des outils de test de boîte noire commerciale qui nous aident à repérer les problèmes de sécurité dans les applications que nous développons.

S. Non Outil
1

NGSSQuirreL

https://www.nccgroup.com/en/our-services

2

IBM AppScan

https://www-01.ibm.com/software/awdtools/appscan/

3

Acunetix Web Vulnerability Scanner

https://www.acunetix.com/

4

NTOSpider

https://www.ntobjectives.com/products/ntospider.php

5

SOAP UI

https://www.soapui.org/Security/getting-started.html

6

Netsparker

https://www.mavitunasecurity.com/netsparker/

sept

HP WebInspect

http://www.hpenterprisesecurity.com/products

Analyseurs de code source gratuits

S. Non Outil
1

OWASP Orizon

https://www.owasp.org/index.php

2

OWASP O2

https://www.owasp.org/index.php/OWASP_O2_Platform

3

SearchDiggity

https://www.bishopfox.com/resources/tools

4

FXCOP

https://www.owasp.org/index.php/FxCop

5

Splint

http://splint.org/

6

Boon

https://www.cs.berkeley.edu/~daw/boon/

sept

W3af

http://w3af.org/

8

FlawFinder

https://www.dwheeler.com/flawfinder/

9

FindBugs

http://findbugs.sourceforge.net/

Analyseurs de code source commercial

Ces analyseurs examinent, détectent et signalent les faiblesses du code source, qui sont sujettes à des vulnérabilités -

S. Non Outil
1

Parasoft C/C++ test

https://www.parasoft.com/cpptest/

2

HP Fortify

http://www.hpenterprisesecurity.com/products

3

Appscan

http://www-01.ibm.com/software/rational/products

4

Veracode

https://www.veracode.com

5

Armorize CodeSecure

http://www.armorize.com/codesecure/

6

GrammaTech

https://www.grammatech.com/