Merci d'avoir envoyé votre demande ! Un membre de notre équipe vous contactera sous peu.
Merci d'avoir envoyé votre réservation ! Un membre de notre équipe vous contactera sous peu.
Plan du cours
1. Sécurité informatique et codage sécurisé
- Principes fondamentaux de la sécurité : Confidentialité, Intégrité et Disponibilité (CIA) dans le contexte des applications Java.
- Cycle de vie de développement logiciel sécurisé (SSDLC) : Intégrer la sécurité dès les exigences jusqu’au déploiement.
- Paradigmes de codage sécurisé : Défense en profondeur, principe du moindre privilège et défauts sécurisés.
- Classifications standard des vulnérabilités : Comprendre la CWE (Common Weakness Enumeration) et l’OWASP.
2. Sécurité des applications web
- Plongée dans l’OWASP Top Ten : Analyse détaillée des injections, de l’authentification rompue et de l’exposition de données sensibles.
- Cross-Site Scripting (XSS) : Scénarios XSS réfléchis, stockés et basés sur le DOM en Java/JSP.
- Cross-Site Request Forgery (CSRF) : Mécanismes d’attaque et mise en œuvre de jetons Anti-CSRF.
- Gestion de session : Sécurité des cookies, fixation de session et gestion du timeout.
- Sécurité des API : Sécurisation des points de terminaison REST et SOAP contre les abus.
3. Sécurité des services web
- Services web vs applications web traditionnelles : Différences dans les surfaces d’attaque.
- Sécurité de la couche de transport : Configuration SSL/TLS pour les clients et serveurs Java.
- Sécurité des messages : Intégrité et confidentialité au niveau du contenu.
- Normes d’authentification : Mise en œuvre d’OAuth 2.0, OpenID Connect et JWT (JSON Web Tokens).
4. Sécurité XML
- Vulnérabilités de l’analyse XML : Prévention des attaques par entité externe XML (XXE).
- Validation du schéma XML : Bonnes pratiques pour une application stricte du schéma.
- Signatures numériques XML : Mise en œuvre de signatures pour assurer la non-répudiation.
- Chiffrement XML : Approches standard pour le chiffrement du contenu XML.
5. Fondements de la sécurité Java
- L’architecture de sécurité Java : Le package
java.securityet l’architecture des fournisseurs. - Fournisseurs de sécurité : Installation et configuration de fournisseurs tels que Bouncy Castle.
- Contrôle d’accès : Fichiers de politique, permissions et gestionnaire de sécurité (Legacy vs. Moderne).
- Gestion du KeyStore : Création et gestion de keystores et truststores pour les certificats.
6. Cryptographie pratique
- Algorithmes cryptographiques : Aperçu des algorithmes symétriques (AES), asymétriques (RSA, ECC) et de hachage (SHA-256/512).
- Génération de nombres aléatoires : Les dangers de
java.util.Randompar rapport àjava.security.SecureRandom. - Gestion des clés : Stratégies de génération, stockage et rotation des clés.
- Architecture de cryptographie Java (JCA) : Utilisation des classes
Cipher,MessageDigestetMac. - Extension de cryptographie Java (JCE) : Compréhension des fichiers de politique et de la juridiction sans restriction de force.
7. Services de sécurité Java
- SSL/TLS dans Java : Utilisation de
SSLSocketFactoryetHttpsURLConnection. - Managers de confiance : Personnalisation de la vérification de confiance pour les environnements PKI privés.
- Authenticators : Authentification programmatique via
Authenticator.getDefault(). - Analyse de certificats : Lecture et analyse programmatique des certificats X.509.
8. Sécurité Java EE
- Sécurité déclarative : Contrôle d’accès basé sur les rôles (RBAC) utilisant
web.xmlet les annotations. - Sécurité programmatique : Utilisation de
HttpServletRequest.isUserInRole()etgetRemoteUser(). - JAS (Java Authentication and Authorization Service) : Configuration de
login.confet mise en œuvre deLoginModules. - Sécurité des servlets : Contraintes de sécurité gérées par le conteneur et méthodes d’authentification (FORM, BASIC, DIGEST).
9. Erreurs de codage courantes et vulnérabilités
- Dé sérialisation non sécurisée : Les risques liés à
ObjectInputStreamet au contournement des contrôles de sécurité. - Injection de commandes : Atténuation des vulnérabilités d’exécution au niveau du système d’exploitation.
- Traversal de chemin : Sanitisation des entrées du système de fichiers pour prévenir la traversal de répertoires.
- Abus de réflexion : Risques associés à
java.lang.reflectet au contournement du contrôle d’accès. - Identifiants codés en dur : Identification et suppression des secrets du code source.
- Erreurs de mise en œuvre cryptographique : Utilisation du mode ECB, de clés faibles ou de vecteurs d’initialisation statiques.
10. Sources de connaissances
- Outils d’analyse statique : Utilisation de SonarQube, Checkmarx et Fortify pour l’analyse automatisée.
- Outils d’analyse dynamique : Aperçu de Burp Suite et OWASP ZAP.
- Bases de données CVE : Comment suivre et réagir aux nouvelles vulnérabilités du framework Java.
- Lectures recommandées : Liste de livres, documentation et listes de vérification de codage sécurisé.
Pré requis
Aucun.
21 Heures
Nos clients témoignent (4)
les connaissances du formateur étaient très élevées - il savait de quoi il parlait et avait les réponses à nos questions
Adam - Fireup.PRO
Formation - Advanced Java Security
Traduction automatique
Exercices pratiques
Olek - Fireup.PRO
Formation - Advanced Java Security
Traduction automatique
exercices de codage
Mirek - Fireup.PRO
Formation - Advanced Java Security
Traduction automatique
Cela ouvre beaucoup et donne de nombreuses perspectives sur la sécurité
Nolbabalo Tshotsho - Vodacom SA
Formation - Advanced Java Security
Traduction automatique