Prenez contact avec nous

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.security et 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.Random vs java.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, MessageDigest et Mac.
  • 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 SSLSocketFactory et HttpsURLConnection.
  • 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.xml et des annotations.
  • Sécurité programmatique : Utilisation de HttpServletRequest.isUserInRole() et getRemoteUser().
  • JASS (Java Authentication and Authorization Service) : Configuration de login.conf et implémentation de LoginModule.
  • 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 à ObjectInputStream et 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.reflect et 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

Nombre de participants


Prix par participant

Nos clients témoignent (4)

Cours à venir

Catégories Similaires