Sécuriser les applications Web .NET et Java
Réf. TACFDEV32
- (Télé)-Présentiel
ENI Service a été retenue par le l'OPCO ATLAS dans le cadre de l'action collective de formation "Développer avec les langages .NET, Java et C++". Si vous êtes salarié d'une entreprise cotisant auprès de l'OPCO ATLAS, vous pouvez bénéficier d'une prise en charge à 100% du coût de cette formation dans la limite des fonds disponibles.
Référence ATLAS : 28068
Dans cette formation, vous apprendrez à sécuriser vos applications objet. Après une présentation des concepts de base sur la sécurité applicative, vous appréhenderez les mécanismes de sécurité des applications Web. Les failles de sécurité courantes, les bonnes pratiques de codage, seront ensuite passées en revu pour optimiser l'approche de sécurisation des développements. Les mécanismes de protection d'accès au code pour isoler une application sur un système seront également évoqués. Les contraintes d'authentification et d'autorisation en lien avec le serveur Web ou l'application, ainsi que les considérations systèmes et les stratégies de tests de sécurité clôtureront cette session.
- Action collective OPCO Atlas
Objectifs
- Identifier et décrire les enjeux de la sécurité
- Identifier et décrire les failles de sécurité et les différents types d’attaques des applications Web
- Sécuriser les accès à une base de données
- Valider les saisies utilisateurs des applications Web
- Identifier et mettre en oeuvres les mécanismes d'authentification et de gestion des autorisations
- Protéger le code des applications
- Définir et exécuter des plans de tests
- Sécuriser et protéger l'intégrité des données échangées sur les réseaux
Pré-requis
Cursus Java :
- Avoir suivi les formations « TACFDEV1B1 - Les fondamentaux de la programmation Java (Java SE) » ET « TACFDEV2B1 - Développement d’applications Web Java EE », ou posséder les connaissances et compétences équivalentes.
Cursus .NET :
- Avoir suivi les formations « TACFDEV1A1 - Les fondamentaux du développement .NET avec le langage C# 7 sous Visual Studio 2017 » et « TACFDEV2A1 - Développer des applications Web ASP.NET Core MVC en C# sous Visual Studio 2017 », ou posséder les connaissances et compétences équivalentes..
Public
Concepteurs / Développeurs, Chefs de projets, Architectes Techniques.
Programme de la formation
Principes de base de la sécurité des applications
- L’importance de la sécurité
- Contre qui et quoi se défendre ?
- Les failles de sécurité classiques
- Comment une attaque survient ?
- Les challenges de la sécurité
- Identification : les différentes méthodes
- Autorisation et permissions d’accès
- Confidentialité : les mécanismes de cryptage
Les bonnes pratiques
- Les patterns de programmation
- La gestion des mots de passe
- Fonctionnalités de cryptage disponibles dans les plateformes de développement
- Les frameworks
- La prise en charge des contre-mesures dans les librairies et frameworks applicatifs
- Travaux pratiques :
- Présentation de librairies et frameworks et de leurs fonctionnalités natives pour la sécurisation des applications dans les différentes plateformes de développement
Sécuriser l’accès aux bases de données
- Scénarii d’authentification vers une base de données
- Les chaînes de connexion et pools de connexions
- Crypter les fichiers de configuration
- Les attaques par SQL Injection
- Différentes techniques pour s’en prémunir
- Travaux pratiques :
- Mise en œuvre d’une application se connectant aux données et mise en œuvre des conditions d’injection SQL puis correction de la faille de sécurité
La sécurité informatique dans un contexte Web
- Le projet OWASP (Open Web Application Security Project)
- Présentation du projet
- Analyse des préconisations et bonnes pratiques du référentiel OWASP
- Les différentes attaques et vulnérabilités des applications et sites Web
- CSRF, XSS, SQL Injection, Remote Code Injection
- Présentation des attaques et des contre-mesures associées
- La théorie des techniques de contre-mesure
- L’apport des frameworks de développement Web pour la sécurité
- Travaux pratiques :
- Importation d’un projet d’application Web
- Identification des failles dans l’application
- Définition de la stratégie de sécurisation
- Observation des requêtes GET et POST, mise en place d’un sniffer de trames réseaux
Validation des données dans les applications Web
- Identifier les sources de données
- Attaques par les cookies, HTTP et JavaScript Injection
- Les contrôles de validation de données
- Gestion des erreurs
- Travaux pratiques :
- Attaque par injection de JavaScript
- Attaque par soumission de formulaire non sécurisé côté serveur
- Attaque d’un site Web et provocation d’un déni de service
Authentification et autorisations dans les applications Web
- Les différents modes d’authentification
- Basic, Digest, Client-Cert, …
- Scénarii d’authentification dans une application Intranet/Internet
- Authentification des applications clientes JavaScript
- Principes et contraintes pour les applications distantes
- Les mécanismes d’authentification : OAuth2, JSON Web Token, …
- Autorisations : les rôles de sécurité
- Définition et déclaration
- Principes de mappage avec l’existant
- Stratégie de sécurité des différents types d’applications
- Paramétrage d’un conteneur Web/d’applications pour la sécurité
- Paramétrage d’un référentiel d’authentification
- Utilisation d’un connecteur HTTPS
- Travaux pratiques :
- Sécuriser un site Web
- Déclaration d’une stratégie de restriction d’accès aux URLs dans une application Web
- Configuration d’un serveur pour l’authentification
- Configurer l’accès HTTPS d’un serveur
Protéger les données, leur transfert et leur l’intégrité
- Introduction à la cryptographie
- Cryptage, hachage et signature
- Cryptage symétrique et asymétrique
- Vérifier l’intégrité des données avec le hachage
- Communication sécurisée avec SSL
- Les API de cryptage et de protection de données
- Travaux pratiques :
- Mise en œuvre d’un cryptage de données sensibles (mot de passe, …)
- Mise en œuvre d’une politique de vérification de l’intégrité des données basées sur le hachage
Sécurité d’accès au code
- Présentation
- Sécurité d’accès au code dans une application
- Bases fondamentales de la sécurité d’accès au code
- Vérifications de sécurité
- Décompilation, protection et obfuscation de code
- Le cas des plateformes Java et .NET
- Stratégie d’accès au code au niveau du Runtime
- Travaux pratiques :
- Création d’une application et mise en place des politiques de sécurité
- Présentation de la décompilation de byte-code
- Présentation d’une solution de brouillage de code
Tester la sécurité des applications
- Scénarii de tests
- Créer un plan de test de sécurité
- Trouver les interfaces à tester
- Tester l’authentification, les autorisations
- Tester les applications We
Formation avec un formateur, qui peut être suivie selon l’une des 3 modalités ci-dessous :
1 – Dans la salle de cours en présence du formateur.
2 – Dans l’une de nos salles de cours immersives, avec le formateur présent physiquement à distance. Les salles immersives sont équipées d’un système de visio-conférence HD et complétées par des outils pédagogiques qui garantissent le même niveau de qualité.
3 – Depuis votre domicile ou votre entreprise. Vous rejoignez un environnement de formation en ligne, à l’aide de votre ordinateur, tout en étant éloigné physiquement du formateur et des autres participants. Vous êtes en totale immersion avec le groupe et participez à la formation dans les mêmes conditions que le présentiel. Pour plus d’informations : Le téléprésentiel – notre solution de formation à distance.
Le nombre de stagiaires peut varier de 1 à 12 personnes (5 à 6 personnes en moyenne), ce qui facilite le suivi permanent et la proximité avec chaque stagiaire.
Chaque stagiaire dispose d’un poste de travail adapté aux besoins de la formation, d’un support de cours et/ou un manuel de référence au format numérique ou papier (pour les sessions inter-entreprises, dans le cas où le support de cours officiel est en anglais, nous offrons en complément, s’il existe, un ouvrage de référence des Editions ENI au format numérique rédigé en français).
Pour une meilleure assimilation, le formateur alterne tout au long de la journée les exposés théoriques, les démonstrations et la mise en pratique au travers d’exercices et de cas concrets réalisés seul ou en groupe.
En début et en fin de formation, les stagiaires réalisent une auto-évaluation de leurs connaissances et compétences en lien avec les objectifs de la formation. L’écart entre les deux évaluations permet ainsi de mesurer leurs acquis.
En complément, pour les stagiaires qui le souhaitent, certaines formations peuvent être validées officiellement par un examen de certification. Les candidats à la certification doivent produire un travail personnel important en vue de se présenter au passage de l’examen, le seul suivi de la formation ne constitue pas un élément suffisant pour garantir un bon résultat et/ou l’obtention de la certification.
Pour certaines formations certifiantes (ex : ITIL, Prince2, DPO, …), le passage de l’examen de certification est inclus et réalisé en fin de formation. Les candidats sont alors préparés par le formateur au passage de l’examen tout au long de la formation.
Feuille de présence, émargée par demi-journée par chaque stagiaire et le formateur ;
Evaluation qualitative de fin de formation, qui est ensuite analysée par l’équipe pédagogique ENI ;
Attestation de fin de formation, remise au stagiaire en main propre ou par courrier électronique.
La formation est animée par un professionnel de l'informatique et de la pédagogie, dont les compétences techniques, professionnelles et pédagogiques ont été validées par des certifications et/ou testées et approuvées par les éditeurs et/ou notre équipe pédagogique. Il est en veille technologique permanente et possède plusieurs années d'expérience sur les produits, technologies et méthodes enseignés. Il est présent auprès des stagiaires pendant toute la durée de la formation.