Dans cette formation, vous apprendrez à sécuriser vos applications objet.
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 défis 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 injection SQL
- Différentes techniques pour s’en prémunir
- Travaux pratiques : Mise en oeuvre d’une application se connectant aux données et mise en oeuvre 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
- 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
- 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
- Attaque par injection de JavaScript
- Attaque par soumission de formulaire non sécurisé côté serveur
- Observation des requêtes GET et POST, mise en place d’un sniffer de trames réseaux
Authentification et autorisations dans les applications web
- Les différents modes d’authentification
- Basic, Digest, Client-Cert, etc.
- 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, etc.
- 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
- 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
Protéger les données, leur transfert et leur intégrité
- Introduction à la cryptographie et au chiffrement
- Cryptage, hachage et signature
- Chiffrement 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, de chiffrement et de protection de données
- Travaux pratiques :
- Mise en oeuvre d’un cryptage de données sensibles (mot de passe, etc.)
- Mise en oeuvre d’une politique de vérification de l’intégrité des données basées sur le hachage
- Chiffrement de données échangées sur le réseau : HTTPS
- Configurer l’accès HTTPS d’un serveur
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
- 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
Sécurité applicative et veille technologique
- La nécessité d’une surveillance permanente
- Les bases de connaissances en sécurité applicative
- Mise en place d’un référentiel de sécurité pour la veille
- Créer un plan de test de sécurité
- Stratégie, implémentation et fréquence d’usage
- Intégrer les correctifs de sécurité dans les opérations de maintenances applicatives
- Travaux pratiques : Création d’un plan de test de sécurité sur une application sécurisée
- Appréhender l’importance de la sécurité
- Présenter et expliquer les failles de sécurité, les différents types d’attaques et vulnérabilités des applications
- Concevoir et développer des applications sécurisées
- Appréhender les différents principes relatifs à la sécurité dans les plateformes de développement logiciel et les mettre en oeuvre
- Déceler les principales failles de sécurités dans les applications et apporter des solutions appropriées
- Appréhender et mettre en oeuvre les bonnes pratiques de codage permettant d’éviter les failles de sécurité dans une application web
- Mettre en place une stratégie de veille technologique pour anticiper les potentielles problématiques de sécurité sur les applications existantes
Depuis votre domicile ou votre entreprise, vous rejoignez un environnement de formation en ligne, à l’aide de votre ordinateur, tout en étant éloigné.e physiquement du/de la formateur.trice et des autres participant.e.s. Vous êtes en totale immersion avec le groupe et participez à la formation dans les mêmes conditions que le présentiel.
En début et en fin de formation, vous réalisez une auto-évaluation de vos connaissances et compétences en lien avec les objectifs de la formation. L’écart entre les deux évaluations permet ainsi de mesurer vos acquis.
Cette formation s’adresse aux développeur.euse.s, analystes programmeur.euse.s, chef.fe.s de projets techniques et architectes.
Prérequis :
Posséder une expérience pratique du développement d’applications web quel que soit le langage de programmation.
Vous recevez une attestation de suivi de cours CPI Formations à la fin de cette formation, pour autant que le taux de présence atteigne 80%.
Intervenant
Intervenant.e de la formation
Intervenant.e de la formation
La formation est animée par un.e professionnel.le 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/Elle est en veille technologique permanente et possède plusieurs années d’expérience sur les produits, technologies et méthodes enseignés. Il/Elle est présent.e auprès des stagiaires pendant toute la durée de la formation.