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 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.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 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.Random par 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, MessageDigest et Mac.
  • 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 SSLSocketFactory et HttpsURLConnection.
  • 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.xml et les annotations.
  • Sécurité programmatique : Utilisation de HttpServletRequest.isUserInRole() et getRemoteUser().
  • JAS (Java Authentication and Authorization Service) : Configuration de login.conf et mise en œuvre de LoginModules.
  • 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 à ObjectInputStream et 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.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 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

Nombre de participants


Prix par participant

Nos clients témoignent (4)

Cours à venir

Catégories Similaires