Formation Comment écrire un Code Sécurisé
À la suite des grandes attaques contre les infrastructures nationales, les professionnels de la sécurité ont constaté que la majorité des vulnérabilités ayant permis ces attaques provenaient de codes mal écrits et vulnérables rédigés par les développeurs.
Les développeurs doivent désormais maîtriser les techniques d'écriture de code sécurisé, car nous vivons une situation où quiconque peut utiliser des outils disponibles pour rédiger un script capable de désactiver efficacement les systèmes d'une grande organisation, simplement parce que les développeurs ont produit du code déficient.
Ce cours vise à aider à ce qui suit :
- Aider les développeurs à maîtriser les techniques d'écriture de code sécurisé
- Aider les testeurs logiciels à vérifier la sécurité de l'application avant sa publication en environnement de production
- Aider les architectes logiciels à comprendre les risques liés aux applications
- Aider les chefs d'équipe à définir les bases de sécurité pour les développeurs
- Aider les responsables web à configurer les serveurs afin d'éviter les erreurs de configuration
Dans ce cours, vous découvrirez également les détails des dernières cyberattaques qui ont été utilisées, ainsi que les contre-mesures employées pour arrêter et prévenir ces attaques.
Vous constaterez par vous-même comment les erreurs des développeurs ont conduit à des attaques catastrophiques, et en participant aux laboratoires pendant le cours, vous pourrez mettre en pratique les contrôles de sécurité et acquérir l'expérience et les connaissances nécessaires pour produire du code sécurisé.
Qui devrait suivre ce cours ?
Cette formation au code sécurisé est idéale pour les personnes occupant des postes tels que, mais sans s'y limiter :
- Développeurs web
- Développeurs mobiles
- Développeurs Java
- Développeurs Dot Net
- Architectes logiciels
- Testeurs logiciels
- Professionnels de la sécurité
- Responsables web
Plan du cours
Module 1 : Introduction au codage sécurisé
- Aperçu des pratiques de codage sécurisé
- Vulnérabilités courantes dans les logiciels
- Importance du cycle de développement sécurisé
Module 2 : Bases des applications Web, Windows et mobiles
- Introduction aux plateformes d'application
- Implications de sécurité pour chaque plateforme
- Meilleures pratiques pour un développement sécurisé
Module 3 : Attaques et exploitations d'applications
- Scripting intersite (XSS)
- Injection SQL
- Falsification de requête intersite (CSRF)
Module 4 : Attaques et exploitations de serveurs
- Attaques par déni de service (DoS)
- Dépassement de tampon (BOF)
- Vulnérabilités courantes des serveurs
Module 5 : Validation et vérification
- Techniques de validation des entrées
- Nettoyage des données et encodage des sorties
- Vérification des mesures de sécurité
Module 6 : Contrôles de sécurité et contre-mesures
- Mise en œuvre du contrôle d'accès
- Utilisation du chiffrement pour la sécurité des données
- Protection contre les menaces courantes
Module 7 : Codage sécurisé pour les applications mobiles
- Questions de sécurité dans le développement mobile
- Mise en œuvre d'architectures d'applications mobiles sécurisées
- Gestion sécurisée des données mobiles
Module 8 : Normes de sécurité et tests
- Aperçu des normes de sécurité (par ex. OWASP)
- Tests de vulnérabilités de sécurité
- Meilleures pratiques pour les tests de sécurité
Pré requis
- Connaissances de base dans un langage de programmation
- Connaissances de base du cycle de vie du développement logiciel
Public visé
- Développeurs
- Architectes logiciels
- Professionnels de la sécurité
Les formations ouvertes requièrent plus de 3 participants.
Formation Comment écrire un Code Sécurisé - Réservation
Formation Comment écrire un Code Sécurisé - Demande de renseignements
Comment écrire un Code Sécurisé - Demande d'informations consulting
Nos clients témoignent (3)
Les ateliers pratiques
Angel - Vodacom
Formation - How to Write Secure Code
Traduction automatique
voir les menaces de sécurité à l'œuvre
kesh - Vodacom
Formation - How to Write Secure Code
Traduction automatique
Module3 Attaques et exploitations d'applications, XSS, injection SQL Module4 Attaques et exploitations de serveurs, DOS, BOF
Tshifhiwa - Vodacom
Formation - How to Write Secure Code
Traduction automatique
Cours à venir
Cours Similaires
Sécurité des réseaux et communications sécurisées
21 HeuresLa mise en œuvre d'une application réseau sécurisée peut s'avérer difficile, même pour des développeurs ayant préalablement utilisé divers composants cryptographiques (tels que le chiffrement et les signatures numériques). Afin que les participants comprennent le rôle et l'utilisation de ces primitives cryptographiques, nous établirons d'abord des bases solides sur les exigences principales de la communication sécurisée – accusé de réception sécurisé, intégrité, confidentialité, identification à distance et anonymat – tout en présentant les problèmes typiques susceptibles de compromettre ces exigences, ainsi que des solutions concrètes.
La cryptographie étant un aspect critique de la sécurité des réseaux, nous aborderons également les algorithmes cryptographiques les plus importants en cryptographie symétrique, en hachage, en cryptographie asymétrique et en échange de clés. Au lieu de proposer un fondement mathématique approfondi, ces éléments sont examinés du point de vue du développeur, avec des exemples d'utilisations typiques et des considérations pratiques liées à l'usage du chiffrement, telles que les infrastructures à clés publiques. Les protocoles de sécurité dans de nombreux domaines des communications sécurisées sont présentés, avec un examen approfondi des familles de protocoles les plus répandues, comme IPSEC et SSL/TLS.
Les vulnérabilités cryptographiques courantes sont analysées, tant en lien avec certains algorithmes cryptographiques qu'avec les protocoles de chiffrement, notamment BEAST, CRIME, TIME, BREACH, FREAK, Logjam, l'attaque par oracle de rembourrage (Padding oracle), Lucky Thirteen, POODLE et similaires, ainsi que l'attaque par chronométrage sur RSA. Dans chaque cas, les implications pratiques et les conséquences potentielles de chaque problème sont décrites, sans entrer dans les détails mathématiques approfondis.
Enfin, la technologie XML étant centrale pour l'échange de données entre applications réseau, nous décrirons les aspects de sécurité liés au XML. Cela inclut l'utilisation du XML dans les services Web et les messages SOAP, ainsi que les mesures de protection telles que la signature XML et le chiffrement XML – mais aussi les faiblesses de ces mécanismes de protection et les problèmes de sécurité spécifiques au XML, comme l'injection XML, les attaques par entités externes XML (XXE), les bombes XML et l'injection XPath.
Les participants suivant cette formation apprendront à
- Comprendre les concepts de base de la sécurité, de la sécurité informatique et du codage sécurisé
- Comprendre les exigences d'une communication sécurisée
- Apprendre les attaques et les défenses réseau aux différentes couches du modèle OSI
- Acquérir une compréhension pratique de la cryptographie
- Comprendre les protocoles de sécurité essentiels
- Comprendre certaines attaques récentes contre les systèmes cryptographiques
- Obtenir des informations sur certaines vulnérabilités récentes apparentées
- Comprendre les concepts de sécurité des services Web
- Disposer de sources et de lectures complémentaires sur les pratiques de codage sécurisé
Public cible
Développeurs, Professionnels
Programmation sécurisée en C/C++
21 HeuresÉcrire du code C et C++ sécurisé exige une défense rigoureuse contre les exploitations malveillantes, la corruption de la mémoire et les contournements de la validation des entrées. Ce programme examine des modèles de vulnérabilités tels que les débordements de tampon, l'utilisation après libération, les débordements entiers et les erreurs de type. Les participants appliquent des directives de codage sécurisé, des outils d'analyse statique et des techniques de programmation défensive pour éliminer les faiblesses, imposer la sanitisation des entrées et livrer un logiciel durci résistant aux cyberattaques.
Sécurité avancée de Java
21 HeuresMême les programmeurs Java expérimentés ne maîtrisent pas nécessairement tous les services de sécurité offerts par Java et ne sont pas non plus conscients des différentes vulnérabilités pertinentes pour les applications web écrites en Java.
Le cours – outre l’introduction aux composants de sécurité de la plate-forme Standard Java Edition – traite des questions de sécurité liées à Java Enterprise Edition (JEE) et aux services web. L’analyse des services spécifiques est précédée par les fondements de la cryptographie et de la communication sécurisée. Divers exercices portent sur les techniques de sécurité déclarative et programmatique dans JEE, tandis que la sécurité au niveau du transport et de bout en bout des services web est abordée. L’utilisation de tous les composants est présentée à travers plusieurs exercices pratiques, permettant aux participants d’expérimenter eux-mêmes les API et outils discutés.
Le cours explore également et explique les failles de programmation les plus fréquentes et graves du langage Java et de sa plateforme, ainsi que les vulnérabilités liées au web. Outre les bugs typiques commis par les programmeurs Java, les vulnérabilités de sécurité introduites couvrent à la fois les problèmes spécifiques au langage et les problèmes découlant de l’environnement d’exécution. Toutes les vulnérabilités et les attaques associées sont démontrées à travers des exercices compréhensibles, suivis des directives de codage recommandées et des techniques d’atténuation possibles.
Les participants suivant ce cours sauront
- Comprendre les concepts de base de la sécurité, de la sécurité informatique et du codage sécurisé
- Apprendre les vulnérabilités web au-delà de l’OWASP Top Ten et savoir comment les éviter
- Comprendre les concepts de sécurité des services web
- Savoir utiliser diverses fonctionnalités de sécurité de l’environnement de développement Java
- Avoir une compréhension pratique de la cryptographie
- Comprendre les solutions de sécurité de Java EE
- Se familiariser avec les erreurs de codage courantes et leur prévention
- Obtenir des informations sur certaines vulnérabilités récentes dans le framework Java
- Acquérir des connaissances pratiques sur l’utilisation des outils de test de sécurité
- Obtenir des sources et des lectures complémentaires sur les pratiques de codage sécurisé
Public
Développeurs
Développement de la sécurité avec .NET, C# et ASP.NET
14 HeuresAujourd'hui, de nombreux langages de programmation permettent de compiler du code pour les environnements .NET et ASP.NET. Cet environnement offre des outils puissants pour le développement de la sécurité, mais les développeurs doivent savoir appliquer les techniques de programmation au niveau de l'architecture et du code afin d'implémenter les fonctionnalités de sécurité souhaitées, éviter les vulnérabilités ou limiter leur exploitation.
Ce cours a pour objectif d'apprendre aux développeurs, à travers de nombreux exercices pratiques, comment empêcher du code non fiable d'effectuer des actions privilégiées, protéger les ressources grâce à une authentification et une autorisation robustes, fournir des appels de procédure à distance (RPC), gérer les sessions, présenter différentes implémentations pour certaines fonctionnalités, et bien plus encore.
L'introduction aux différentes vulnérabilités commence par la présentation de problèmes de programmation typiques commis lors de l'utilisation de .NET. La discussion sur les vulnérabilités d'ASP.NET traite également de divers paramètres d'environnement et de leurs effets. Enfin, le sujet des vulnérabilités spécifiques à ASP.NET aborde non seulement certains défis généraux de sécurité des applications web, mais aussi des problèmes particuliers et des méthodes d'attaque, telles que l'attaque de ViewState ou les attaques par terminaison de chaîne.
Les participants à ce cours seront capables de
- Comprendre les concepts de base de la sécurité, de la sécurité informatique et du codage sécurisé
- Apprendre les vulnérabilités web au-delà du OWASP Top Ten et savoir comment les éviter
- Apprendre à utiliser les diverses fonctionnalités de sécurité de l'environnement de développement .NET
- Obtenir des connaissances pratiques sur l'utilisation des outils de test de sécurité
- Apprendre à connaître les erreurs de codage courantes et savoir comment les éviter
- Obtenir des informations sur certaines vulnérabilités récentes dans .NET et ASP.NET
- Obtenir des sources et des lectures complémentaires sur les pratiques de codage sécurisé
Public cible
Développeurs
Programmation sécurisée en PHP
21 HeuresLe cours dispensent les compétences essentielles pour les développeurs PHP afin de rendre leurs applications résistantes aux attaques contemporaines via Internet. Les vulnérabilités web sont abordées à travers des exemples en PHP qui dépassent le OWASP Top Ten, traitant de divers types d'attaques par injection, d'injections de scripts, d'attaques contre la gestion de session de PHP, de références directes d'objets non sécurisées, de problèmes liés aux téléchargements de fichiers, et bien d'autres. Les vulnérabilités liées à PHP sont présentées regroupées par les types standards de vulnérabilités : validation d'entrée manquante ou inadéquate, gestion incorrecte des erreurs et des exceptions, utilisation inadéquate des fonctionnalités de sécurité et problèmes liés au temps et à l'état. Pour ces derniers, nous discuterons d'attaques comme l'évasion de open_basedir, le déni de service par le biais de magic float ou l'attaque par collision de table de hachage. Dans tous les cas, les participants prendront familiarité avec les techniques et fonctions les plus importantes à utiliser pour atténuer les risques énumérés.
Un accent particulier est mis sur la sécurité côté client, en abordant les problèmes de sécurité de JavaScript, Ajax et HTML5. Un certain nombre d'extensions liées à la sécurité pour PHP sont introduites comme hash, mcrypt et OpenSSL pour la cryptographie, ou Ctype, ext/filter et HTML Purifier pour la validation des entrées. Les meilleures pratiques de durcissement sont données en relation avec la configuration de PHP (paramètres de php.ini), Apache et le serveur en général. Enfin, une vue d'ensemble est donnée sur divers outils et techniques de test de sécurité que les développeurs et testeurs peuvent utiliser, y compris les scanners de sécurité, les tests de pénétration, les paquets d'exploitation, les analyseurs de paquets, les serveurs proxy, les outils de fuzzing et les analyseurs statiques de code source.
Tant l'introduction des vulnérabilités que les pratiques de configuration sont soutenues par un certain nombre d'exercices pratiques démontrant les conséquences des attaques réussies, montrant comment appliquer les techniques d'atténuation et introduire l'utilisation de diverses extensions et outils.
Les participants suivants de ce cours vont
- Comprendre les concepts de base de la sécurité, la sécurité informatique et la programmation sécurisée
- Apprendre les vulnérabilités web au-delà du OWASP Top Ten et savoir comment les éviter
- Apprendre les vulnérabilités côté client et les pratiques de programmation sécurisée
- Avoir une compréhension pratique de la cryptographie
- Apprendre à utiliser diverses fonctionnalités de sécurité de PHP
- Apprendre les erreurs courantes de codage et comment les éviter
- Être informé des récentes vulnérabilités du framework PHP
- Obtenir des connaissances pratiques sur l'utilisation des outils de test de sécurité
- Obtenir des sources et lectures complémentaires sur les pratiques de programmation sécurisée
Public
Développeurs
Microsoft SDL Core
14 HeuresLa formation fondamentale combine du SDL (Secure Development Lifecycle) offre un aperçu de la conception sécurisée, du développement et des tests logiciels via le Cycle de Développement Sécurisé de Microsoft (SDL). Elle propose une vue d'ensemble de niveau 100 des blocs de construction fondamentaux du SDL, suivie de techniques de conception à appliquer pour détecter et corriger les failles aux étapes précoces du processus de développement.
En ce qui concerne la phase de développement, le cours présente un aperçu des bugs de programmation courants ayant une incidence sur la sécurité, tant pour le code managé que natif. Les méthodes d'attaque sont exposées pour les vulnérabilités discutées, ainsi que les techniques d'atténuation associées, le tout expliqué à travers une série d'exercices pratiques offrant aux participants une expérience de piratage concret et interactif. L'introduction des différentes méthodes de tests de sécurité est suivie par la démonstration de l'efficacité de divers outils de test. Les participants peuvent comprendre le fonctionnement de ces outils grâce à de nombreux exercices pratiques consistant à appliquer ces outils sur du code vulnérable déjà étudié.
Les participants suivant ce cours
Comprendront les concepts de base de la sécurité, de la sécurité informatique et de la programmation sécurisée.
Se familiariseront avec les étapes essentielles du Cycle de Développement Sécurisé de Microsoft.
Apprendront les pratiques de conception et de développement sécurisées.
Apprendront les principes de mise en œuvre sécurisée.
Comprendront la méthodologie des tests de sécurité.
- Obtiendront des sources et des lectures complémentaires sur les pratiques de codage sécurisé.
Public cible
Développeurs, Responsables.
Sécurité DevOps : Élaborer une stratégie de sécurité DevOps
7 HeuresDans ce cours en direct dirigé par un formateur à Belgique, les participants apprendront comment élaborer une stratégie de sécurité appropriée pour relever le défi de la sécurité DevOps.
DevSecOps en Feu : Brèche, Correction et Renforcement
7 Heurescet atelier de classe mondiale, à la pointe de la technologie et pratique plonge les participants dans les réalités critiques de la sécurité des pipelines CI/CD modernes. Conçu pour les professionnels de la sécurité, les ingénieurs DevOps et les développeurs désireux de maîtriser la défense avancée contre les brèches de pipeline, cette formation combine des simulations d'attaques en direct avec des outils de pointe et des techniques de défense pratiques.
Ingénieur DevSecOps Certifié EC-Council (ECDE)
28 HeuresL'Ingénieur DevSecOps Certifié EC-Council (ECDE) est un cours pratique conçu pour doter les professionnels des compétences nécessaires pour intégrer la sécurité tout au long du cycle de vie DevOps, permettant ainsi un développement logiciel sécurisé, de la planification au déploiement.
Ce cours en présentiel animé par un instructeur (en ligne ou sur site) s'adresse aux professionnels intermédiaires du développement logiciel et de l'ingénierie DevOps qui souhaitent intégrer des pratiques de sécurité dans les pipelines CI/CD, garantissant ainsi la livraison d'un code sécurisé et conforme.
À l'issue de cette formation, les participants seront capables de :
- Comprendre les principes et pratiques du DevSecOps.
- Sécuriser chaque étape du pipeline CI/CD à l'aide d'outils automatisés.
- Mettre en œuvre des pratiques de codage sécurisé et des analyses de vulnérabilités.
- Se préparer à la certification ECDE grâce à des laboratoires pratiques et une révision ciblée.
Format de la formation
- Cours interactif et discussions.
- Mise en pratique des outils DevSecOps dans des pipelines simulés.
- Exercices guidés axés sur le développement et le déploiement sécurisés.
Options de personnalisation de la formation
- Pour demander une formation personnalisée pour ce cours, adaptée aux workflows ou à la chaîne d'outils de votre équipe, veuillez nous contacter pour en convenir.
Sécurité OWASP GenAI
14 HeuresBasé sur les dernières directives du projet OWASP GenAI Security, les participants apprendront à identifier, évaluer et atténuer les menaces spécifiques à l'IA grâce à des exercices pratiques et des scénarios réels.
OWASP Top 10 2025
14 HeuresCette formation en direct, animée par un formateur, à Belgique (en ligne ou en présentiel), s'adresse aux développeurs web et aux responsables souhaitant explorer et implémenter la norme de référence OWASP Top 10 pour sécuriser leurs applications web.
À l'issue de cette formation, les participants seront en mesure d'élaborer des stratégies, de mettre en œuvre, de sécuriser et de superviser leurs applications web et services en utilisant le document OWASP Top 10.
Guide OWASP de tests de sécurité Web
21 HeuresCette formation en présentiel ou à distance dans <lieu>, animée par un formateur, s'adresse aux développeurs, ingénieurs et architectes qui souhaitent appliquer le cadre, les principes et les techniques de test du WSTG afin de sécuriser leurs applications et services Web.
À l'issue de cette formation, les participants seront en mesure de :
- Utiliser le WSTG pour mettre en œuvre des processus et techniques de tests tout au long du cycle de développement Web.
- Explorer différentes techniques de test afin d'adapter le cadre WSTG en fonction des besoins métier.
- Réaliser diverses méthodes de tests de sécurité pour protéger les applications Web contre les risques et les attaques.
- Rédiger un rapport d'évaluation documentant les résultats et les constatations des tests de sécurité.
Développeur Java sécurisé (incluant OWASP)
21 HeuresCe cours couvre les concepts et principes de codage sécurisé avec Java, en se basant sur la méthodologie de test du Open Web Application Security Project (OWASP). Le Open Web Application Security Project est une communauté en ligne qui crée des articles, méthodologies, documentation, outils et technologies librement accessibles dans le domaine de la sécurité des applications web.
Développeur sécurisé .NET (inclus OWASP)
21 HeuresCe cours aborde les concepts et principes de codage sécurisé avec ASP.NET à travers la méthodologie de test du Open Web Application Security Project (OWASP). OWASP est une communauté en ligne qui crée des articles, méthodologies, documentation, outils et technologies freely disponibles dans le domaine de la sécurité des applications web.
Ce cours explore les fonctionnalités de sécurité du framework .NET et comment sécuriser les applications web.