Evolution MM

Formations à l'informatique
Découvrez la différence ENI

Lien accueil

Téléchargez le Calendrier des formations

Nantes, Rennes, Niort, Nice, Paris

jusqu'à juillet 2018

Rechercher
Rechercher une formation
 

Sécuriser les applications .NET (action collective FAFIEC "Evoluer vers le développement objet" réf. 26859)

ENI Service a été retenue par le FAFIEC dans le cadre de l'action collective de formation "Evoluer vers le développement objet .NET et Java". Si vous êtes salarié d'une entreprise cotisant au FAFIEC, vous pouvez bénéficier d'une prise en charge à 100% du coût de cette formation dans la limite des fonds disponibles.

Dans cette formation, vous apprendrez à sécuriser vos applications .NET et les ressources associées (IIS, SQL Server).

Public :

  • Développeurs, analystes programmeurs, chefs de projets.

Objectifs :

  • Comprendre l'importance de la sécurité ;
  • Présenter et expliquer les failles de sécurité ;
  • Concevoir et développer des applications .NET sécurisées ;
  • Déceler les principales failles de sécurités dans les applications .NET, et apporter des solutions appropriées.

Pré-requis :

  • Idéalement, avoir suivi les formations " T4ACF-1A1 - Les fondamentaux du développement .NET avec le langage C# 7 sous Visual Studio 2017 " et " T4ACF-2A1 - Développer des applications Web ASP.NET Core MVC en C# sous Visual Studio 2017 ", ou posséder les connaissances et compétences équivalentes.

Contenu pédagogique

Présentation de la sécurité dans les applications .NET

  • L'importance de la sécurité
  • Contre qui et quoi se défendre ?
  • Les failles de sécurité classiques
  • Comment une attaque survient ?
  • Les challenges de la sécurité

Conseils pour la création d'applications .NET sécurisées

  • Se protéger contre les attaques courantes
  • Réduire la surface d'attaque
  • Se méfier des données des utilisateurs
  • Gérer correctement les erreurs
  • Tester la sécurité
  • Utiliser le DotFuscator
  • Signer les assemblies
  • Travaux pratiques :
    • Décompilation et altération d'une assembly non signée
    • Mise en œuvre d'un code de piratage d'une application

Modélisation des menaces dans les applications .NET

  • Chronologie de développement d'une application sécurisée
  • Processus de modélisation des menaces

Validation des données dans les applications Web

  • Identifier les sources de données
  • Attaques par les cookies, HTTP et JavaScript Injection
  • Les contrôles de validation de données
  • Gestion des erreurs
  • Travaux pratiques :
    • Attaque par injection de JavaScript
    • Attaque par soumission de formulaire non sécurisé côté serveur
    • Attaque d'un site web et provocation d'un déni de service

Authentification Server Web IIS

  • Importance de la protection des serveurs Web
  • Authentification et Autorisations
  • Restreindre l'accès aux applications Web
  • Permissions sur les applications Web dans IIS
  • Les modes d'authentification
  • L'authentifications OAuth2
  • Scénarii d'authentification dans une application Intranet/Internet
  • Emprunt d'identité et délégation
  • Gestion de l'identité de l'utilisateur
  • Améliorations de la sécurité dans IIS
  • Travaux pratiques :
    • Sécuriser un site Web.
    • Configurer correctement IIS pour l'hébergement d'une application Web

Sécuriser une application ASP.NET et ses ressources

  • Présentation
  • Authentification Windows et personnalisée
  • Gestion des autorisations
  • L'API de sécurité du Framework .NET
  • Traitement des requêtes HTTP
  • Créer un handler HTTP personnalisé
  • Travaux pratiques :
    • Sécuriser le fichier web.config et crypter les données sensibles
    • Mettre en place les directives appropriées de sécurisation applicative
    • Observation des requêtes GET et POST, mise en place d'un sniffer de trames réseaux

Concepts de sécurité basée sur les rôles

  • Présentation
  • Identités et entités de sécurité
  • Création d'identités et d'entités de sécurité Windows
  • Création d'identités et d'entités de sécurité génériques
  • Vérification de l'identité et de sécurité

Sécurité d'accès au code

  • Présentation
  • Sécurité d'accès au code dans une application .NET
  • Bases fondamentales de la sécurité d'accès au code
  • Vérifications de sécurité
  • Travaux pratiques :
    • Création d'une application et mise en place des politiques de sécurité
    • Accès aux ressources basées sur les rôles

Sécuriser l'accès aux bases de données SQL Server

  • Scénarii d'authentification SQL Server
  • Choix d'authentification sous SQL Server
  • Les chaînes de connexion et pools de connexions
  • Crypter le fichier de configuration
  • Les attaques SQL Injection
  • Travaux pratiques : Mise en œuvre d'une application se connectant aux données et mise en œuvre des conditions d'injection SQL puis correction de la faille de sécurité

Protéger les données, leur transfert et leur l'intégrité

  • Introduction à la cryptographie
  • Cryptage, hachage et signature
  • Cryptage symétrique et asymétrique
  • Vérifier l'intégrité des données avec le hachage
  • Communication sécurisée avec SSL
  • Les API de cryptage et de protection de données
  • Cryptographie dans le Framework .NET
  • Les limites de la classe String et la classe SecureString
  • Travaux pratiques :
    • Mise en œuvre d'un cryptage Rijndael
    • Mise en œuvre d'une politique de vérification de l'intégrité des données basées sur la hashage

Les jetons de sécurité

  • Jetons : UserName Token, Binary Token
  • JWS
  • Certificat X.509

Sécurité et développement Web

  • Classification des attaques : STRIDE, OWASP
  • Les erreurs classiques
  • Attaque par injection
  • XSS (Injection croisée de code)

Tester la sécurité des applications .NET

  • Scénarios de tests
  • Créer un plan de test de sécurité
  • Trouver les interfaces à tester
  • Tester l'authentification, les autorisations
  • Tester les pages ASP .NET


Modalité et moyens pédagogiques, techniques et d'encadrement

  • Formation avec un formateur, dans une salle dédiée à la formation, équipée d'un vidéoprojecteur, d'un tableau blanc et d'une solution de visio-conférence dans le cas des formations suivies en in-classTM (présentiel à distance). Le nombre de stagiaires peut varier de 1 à 12 personnes (5 à 6 personnes en moyenne), ce qui facilite le suivi permanent et la proximité avec chaque stagiaire.
  • Chaque stagiaire dispose d'un poste de travail adapté aux besoins de la formation, d'un support de cours et/ou un manuel de référence au format numérique ou papier (pour les sessions inter-entreprises, dans le cas où le support de cours officiel est en anglais, nous offrons en complément, s'il existe, un ouvrage de référence des Editions ENI au format numérique rédigé en français).
  • Pour une meilleure assimilation, le formateur alterne tout au long de la journée les exposés théoriques, les démonstrations et la mise en pratique au travers d'exercices et de cas concrets réalisés seul ou en groupe. La répartition du temps entre la théorie et la pratique est mentionnée dans le plan de cours.

Modalités d'évaluation des acquis

  • L'évaluation des acquis se fait tout au long de la formation au travers des différents travaux dirigés et travaux pratiques réalisés par le stagiaire.
  • En complément, pour les stagiaires qui le souhaitent, certaines formations peuvent être validées officiellement par un examen de certification. Pour les formations concernées, l'examen est mentionné dans la zone " Commentaire " du programme de formation. Les candidats doivent produire un travail personnel important en vue de se présenter au passage de l'examen, le seul suivi de la formation ne constituant pas un élément suffisant pour garantir un bon résultat et/ou l'obtention de la certification.

Moyens de suivi d'exécution et appréciation des résultats

  • Feuille de présence, émargée par demi-journée par chaque stagiaire et le formateur ;
  • Evaluation qualitative de fin de formation, qui est ensuite analysée par notre équipe pédagogique ;
  • Attestation de fin de formation, remise au stagiaire en main propre ou par courrier électronique.

Qualification du formateur

  • La formation est animée par un professionnel de l'informatique et de la pédagogie, dont les compétences techniques, professionnelles et pédagogiques ont été validées par des certifications et/ou testées et approuvées par les éditeurs et/ou notre équipe pédagogique. Il est en veille technologique permanente et possède plusieurs années d'expérience sur les produits, technologies et méthodes enseignés. Il est présent auprès des stagiaires pendant toute la durée de la formation.