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 développement de logiciels 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, privilège minimum 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 le top dix OWASP : Analyse détaillée des injections, de l'authentification rompue et de l'exposition de données sensibles.
- XSS (Cross-Site Scripting) : Scénarios XSS réfléchis, stockés et basés sur le DOM dans Java/JSP.
- CSRF (Cross-Site Request Forgery) : Mécanismes d'attaque et mise en œuvre de jetons anti-CSRF.
- Gestion des sessions : Sécurité des cookies, fixation de session et gestion des délais d'expiration.
- 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 payload.
- Normes d'authentification : Implémentation d'OAuth 2.0, OpenID Connect et JWT (JSON Web Tokens).
4. Sécurité XML
- Vulnérabilités d'analyse XML : Prévention des attaques XXE (XML External Entity).
- Validation des schémas XML : Meilleures pratiques pour un respect strict des schémas.
- Signatures numériques XML : Mise en œuvre de signatures pour garantir la non-répudiation.
- Chiffrement XML : Approches standard pour chiffrer le 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 stratégie, autorisations et gestionnaire de sécurité (Legacy vs Moderne).
- Gestion des magasins de clés : Création et gestion de magasins de clés (keystores) et de confiance (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.Randomvsjava.security.SecureRandom. - Gestion des clés : Génération, stockage et stratégies de rotation des clés.
- Architecture Java Cryptography (JCA) : Utilisation des classes
Cipher,MessageDigestetMac. - Extension Java Cryptography (JCE) : Compréhension des fichiers de stratégie et de la jurisdiction de force illimitée.
7. Services de sécurité Java
- SSL/TLS dans Java : Utilisation de
SSLSocketFactoryetHttpsURLConnection. - Gestionnaires de confiance : Personnalisation de la vérification de confiance pour les environnements PKI privés.
- Authentificateurs : Authentification programmatique à l'aide de
Authenticator.getDefault(). - Analyse des certificats : Lecture et analyse programmatiques des certificats X.509.
8. Sécurité Java EE
- Sécurité déclarative : Contrôle d'accès basé sur les rôles (RBAC) à l'aide de
web.xmlet des annotations. - Sécurité programmatique : Utilisation de
HttpServletRequest.isUserInRole()etgetRemoteUser(). - JASS (Java Authentication and Authorization Service) : Configuration de
login.confet implémentation deLoginModule. - 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 et vulnérabilités courantes
- Désérialisation non sécurisée : Les risques liés à
ObjectInputStreamet au contournement des vérifications 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 les traversées de répertoires.
- Abus de la 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 IV 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 contrôle 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