Développement d'une application Web avec ASP.NET MVC



Documents pareils
La double authentification dans SharePoint 2007

Sage CRM. 7.2 Guide de Portail Client

Construire une application marketing Facebook sur la plateforme Windows Azure

Gestion de l authentification et des autorisations

Authentification avec CAS sous PRONOTE.net Version du lundi 19 septembre 2011

MEDIAplus elearning. version 6.6

Microsoft Application Center Test

Sécurisation d une application ASP.NET

Création d'un site dynamique en PHP avec Dreamweaver et MySQL

Reporting Services - Administration


Vérification intégrée de l'utilisateur Guide d'implémentation client Confidentiel Version 2.9

TP JAVASCRIPT OMI4 TP5 SRC

Procédures Stockées WAVESOFT ws_sp_getidtable Exemple : ws_sp_getnextsouche Exemple :... 12

Interagir avec le SharePoint. Version 1.0

PRODIGE V3. Manuel utilisateurs. Consultation des métadonnées

1. Introduction Création d'une macro autonome Exécuter la macro pas à pas Modifier une macro... 5

Déploiement d'une base SQL Express

Corrigé de l'atelier pratique du module 8 : Implémentation de la réplication

CARPE. Documentation Informatique S E T R A. Version Août CARPE (Documentation Informatique) 1

FileSender par RENATER - Guide utilisateur

Sauvegarde des bases SQL Express

INTRODUCTION AUX TESTS DE PERFORMANCE ET DE CHARGE

Module Com231A - Web et Bases de Données Notion 5 : Formulaires et utilisation des Bases de Données avec PHP

Sommaire Accès via un formulaire d'identification... 4 Accès en mode SSO... 5 Quels Identifiant / mot de passe utiliser?... 6

contact@nqicorp.com - Web :

Architectures web/bases de données

À propos du Guide de l'utilisateur final de VMware Workspace Portal

La réplication sous SQL Server 2005

Manuel d utilisation NETexcom

Accès externe aux ressources du serveur pédagogique

Application web de gestion de comptes en banques

GESTION DES BONS DE COMMANDE

Les Utilisateurs dans SharePoint

< Atelier 1 /> Démarrer une application web

STATISTICA Version 12 : Instructions d'installation

FORMATION PcVue. Mise en œuvre de WEBVUE. Journées de formation au logiciel de supervision PcVue 8.1. Lieu : Lycée Pablo Neruda Saint Martin d hères

PMI PLACE DE MARCHE INTERMINISTERIELLE GUIDE D'UTILISATION UTILISATEUR OPERATEUR ECONOMIQUE

Assistance à distance sous Windows

Service de certificat

SafeGuard Enterprise Web Helpdesk. Version du produit : 6.1

Authentification et contrôle d'accès dans les applications web

Serveur d'application Client HTML/JS. Apache Thrift Bootcamp

PHP 5.4 Développez un site web dynamique et interactif

A DESTINATION DES SERVICES TIERS. Editeurs d applications et ressources pédagogiques connectées à l ENT

Initiation à html et à la création d'un site web

ASP.NET MVC 4 Développement d'applications Web en C# - Concepts et bonnes pratiques

Classe ClInfoCGI. Fonctions membres principales. Gestion des erreurs

Conception d'un système d'information WEB avec UML Par Ass SERGE KIKOBYA

Sql Server 2005 Reporting Services

Comment développer et intégrer un module à PhpMyLab?

Alfresco Guide Utilisateur

Stockage du fichier dans une table mysql:

Application de lecture de carte SESAM-Vitale Jeebop

Flex. Lire les données de manière contrôlée. Programmation Flex 4 Aurélien VANNIEUWENHUYZE

Avant-propos 1. Avant-propos Organisation du guide À qui s'adresse ce guide?...4

Rafraichissement conditionné d'une page en.net

Le meilleur de l'open source dans votre cyber cafe

Créer un rapport pour Reporting Services

Procédure d'installation complète de Click&Decide sur un serveur

Procédure d'authentification sur Extradoc

DOSSIER D'ACTIVITES SUR LE PHP N 03 Créer une base de données MySQL avec PHPMyAdmin

Création d'un questionnaire (sondage)

Présentation du Framework BootstrapTwitter

Devenez un véritable développeur web en 3 mois!

Microsoft OSQL OSQL ou l'outil de base pour gérer SQL Server

SHERLOCK 7. Version du 01/09/09 JAVASCRIPT 1.5

K?ellaWeb Saisie des absences, retards et sanctions APLON en mode Web

Gestion du parc informatique des collèges du département du Cher. Manuel d utilisation de la solution de gestion de Parc

LES ACCES ODBC AVEC LE SYSTEME SAS

Manuel d utilisation de la plate-forme de gestion de parc UCOPIA. La mobilité à la hauteur des exigences professionnelles

Sage CRM. Sage CRM 7.3 Guide du portable

Préparer la synchronisation d'annuaires

STID 2ème année : TP Web/PHP

Développement d'applications Web HTML5 L'art et la manière avec Visual Studio 2015 et TFS

Acronis Backup & Recovery 10 Advanced Server Virtual Edition. Guide de démarrage rapide

Joomla! Création et administration d'un site web - Version numérique

WEB & DÉVELOPPEMENT LES BASES DU WEB LE LANGAGE HTML FEUILLES DE STYLES CSS HISTORIQUE D INTERNET ET DU WEB LES DIFFÉRENTS LANGAGES

Formation. Module WEB 4.1. Support de cours

Serveur d application WebDev

Compte-rendu de projet de Système de gestion de base de données

EXTRANET STUDENT. Qu'est ce que Claroline?

Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère

TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile

TAGREROUT Seyf Allah TMRIM

SafeGuard Enterprise Web Helpdesk. Version du produit : 5.60

Déploiement d'une application Visual Studio Lightswitch dans Windows Azure.

Guide d'utilisation du portail d'authentification Cerbère à usage des professionnels et des particuliers

Projet 2. Gestion des services enseignants CENTRE D ENSEIGNEMENT ET DE RECHERCHE EN INFORMATIQUE. G r o u p e :

Utiliser Reporting Services pour des NewsLetter

Module BD et sites WEB

MEGA ITSM Accelerator. Guide de Démarrage

contact@nqicorp.com - Web :

HP Data Protector Express Software - Tutoriel 3. Réalisation de votre première sauvegarde et restauration de disque

Programmation Web. Madalina Croitoru IUT Montpellier

TP3-2 CONSTRUISEZ VOTRE PREMIER SERVICE AZURE

Transcription:

Développement d'une application Web avec ASP.NET MVC A. Introduction A.1. Présentation Depuis la version 3.5 du Framework.NET, Microsoft propose sous forme d'extensions, un nouveau modèle de conception et de développement d'applications Web, nommé ASP.NET MVC. Nous verrons qu'il ne s'agit en aucun cas d'une technologie remplaçant la technologie ASP.NET WebForms, que nous avons utilisé dans le chapitre précédent, mais d'une alternative. En effet, le modèle MVC est un modèle de développement reconnu ayant fait ses preuves dans d'autres technologies telles que les technologies J2EE et PHP. Microsoft a simplement décidé de proposer une implémentation de ce modèle, que nous allons étudier pour créer une application Web. A.2. Présentation du modèle ASP.NET MVC Le modèle ASP.NET MVC, où MVC est l'acronyme de Modèle Vue Contrôleur, permet de créer des applications Web composée : D'un modèle, constitué d'un ensemble de classes permettant de créer les objets métiers manipulés dans l'application, et d'exécuter les traitements métiers. De vues constituant des éléments graphiques tels que des contrôles utilisateurs, des pages Web ou encore des Master Pages. Ces éléments graphiques sont implémentés de manière radicalement différente par rapport à leurs homologues en ASP.NET WebForms. De contrôleurs permettant de piloter l'application, d'exécuter des actions et fournir une vue en réponse aux requêtes reçues. L'une des fonctionnalités fondamentales des contrôleurs est d'assurer la communication entre le modèle et la vue. A.3. ASP.NET VS ASP.NET MVC A.3.a. Les différences entre les applications ASP.NET WebForms et ASP.NET MVC Même si leur but est identique, à savoir construire des applications Web, la conception et le développement d'une application ASP.NET MVC est très différente d'une application ASP.NET WebForms. Voici les principales caractéristiques d'asp.net MVC qui le différencient : Page 1 sur 41

ASP.NET MVC permet de structurer davantage l application, en créant des composants avec des rôles bien identifiés. ASP.NET MVC ne supporte pas les posts-backs classiques et l'utilisation du ViewState. L utilisation des contrôles ASP.NET n est pas encouragée. Même s il s agit d un facteur de ralentissement dans le développement d une application Web, il permet de mieux contrôler le flux XHTML renvoyé au client Web (rendu des contrôles, données dans le flux, ). Pour échanger des informations entre les clients Web et le serveur IIS, ASP.NET MVC utilise le modèle REST (REpresentational State Transfer). Chaque page est divisée en deux composants distincts (un contrôleur et une vue) qui agissent sur le même modèle de données. ASP.NET MVC utilise un modèle nommé Front Controller, qui permet de traiter les requêtes de l'application Web par l'intermédiaire du routage et d'un contrôleur. ASP.NET MVC ne considère pas une URL comme un point de terminaison vers un fichier d une application. Une URL est considérée comme un moyen d accéder à une ressource (logique) sur le serveur, mais pas nécessairement un fichier ASPX à exécuter. Nous aurons alors l occasion de voir que les URLs possèdent un format particulier de type /Controleur/action/id. ASP.NET MVC offre un meilleur support pour le développement dirigé par les tests (Test Driven Development). Lors de la création d un projet de type ASP.NET MVC, Microsoft propose de créer un projet de test, qui permettra de tester au fur et à mesure du développement de l application. A.3.b. Choisir entre ASP.NET WebForms et ASP.NET MVC Le modèle MVC est un modèle de développement ayant fait ses preuves dans d autres technologies de développement d applications Web telles que la technologie J2EE. Quand aux pages ASP.NET Web Forms, la vue (page ASPX) manque de souplesse dans le sens où elle doit souvent contenir trop de traitements ne facilitant pas le découpage en couche de l application. Le modèle MVC permet d agir sur la conception et le développement de l application en assurant un découpage en couche. Mais sa contrepartie réside dans un développement plus coûteux en temps. Le choix entre les pages WebForms et les pages MVC se fera en fonction de l évaluation des critères suivants : nombre de pages Web dans le projet, exigence en matière d architecture (la présence d un architecte étant souhaitée), connaissances des développeurs en matière d architecture, temps alloué pour développer le projet B. Exécution d'une requête HTTP Pour créer une application avec ASP.NET MVC, il est important de comprendre comment est traitée une requête HTTP à destination d'une page ASP.NET MVC : Page 2 sur 41

1 - Un utilisateur envoie au travers d'un client Web une requête vers une application ASP.NET MVC. 2 - Le module UrlRoutingModule intercepte la requête pour la router en fonction des routes définies dans la table de routage (créée lors du démarrage de l'application). Cette requête ne vise pas une page directement une page. Elle désigne une action d'un contrôleur. Si aucune action n'est précisée dans la requête HTTP, alors il s'agit de l'action Index par défaut qui est exécutée sur le contrôleur. Si le contrôleur n'est pas présent, alors l'action Index est exécutée sur le contrôleur Home. Ce contrôleur et action par défaut sont définis dans le fichier global.asax. Le module UrlRoutingModule est défini dans le fichier de configuration : <httpmodules> <add name="urlroutingmodule" type="system.web.routing.urlroutingmodule, System.Web.Routing, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/> </httpmodules> Page 3 sur 41

3 ; 4 et 5 - Le contrôleur s'exécutant, peut faire appel au modèle pour consulter de la base de données, exécuter des traitements métiers, mettre à jour des données 6 - Le contrôleur demande à un vue de s'exécuter, afin de présenter des données à l'utilisateur et recueillir ses futures demandes. C. Création de l'application MVC C.1. Création du projet ASP.NET MVC Après avoir lancé Visual Studio 2010, créons un nouveau projet de type Application ASP.NET MVC. Après avoir cliqué sur le bouton OK, la fenêtre suivante apparaît : Page 4 sur 41

Cette fenêtre propose de créer un projet de test, permettant de tester notre application ASP.NET MVC au fur et à mesure de son développement. Nous refusons cette proposition et cliquons sur le bouton OK. Dans l'explorateur de solutions de Visual Studio, nous observons la présence d'un ensemble de répertoires et de fichiers : Page 5 sur 41

Notre application ASP.NET MVC possède une structure particulière, que nous allons devoir respecter. Elle est constituée : D'un répertoire Content, qui contiendra les éléments graphiques et de présentation de notre application : feuilles de styles CSS et XSLT, images... D'un répertoire Controllers, qui contiendra tous les contrôleurs de notre application. D'un répertoire Models, qui contiendra les classes qui constituent le modèle de l'application ASP.NET MVC. Dans notre cas, le modèle est existant et externalisé dans le projet de type bibliothèque de classes nommé LearningCompany_DAO. D'un répertoire Scripts, contenant les scripts JavaScript de l'application. Par défaut, ce répertoire contient les fichiers JavaScript composant les Frameworks JQuery et Ajax spécifiques pour ASP.NET MVC. Le fichier global.asax définit le routage par défaut de notre application. Il s'agit d'un concept déjà présent dans la version 3.5 du Framework.NET. Dans les applications ASP.NET MVC, Microsoft l'utilise pour permettre d'exécuter une Page 6 sur 41

action d'un contrôleur à partir d'une URL. Il est aussi possible de personnaliser le routage en définissant ses propres règles. Par exemple, soit l'url suivante : http://www.monsite.fr/uncontroleur/uneaction/unparametre. Pour définir une route correspondant à cette URL, nous ajoutons le bloc de code suivant la méthode RegisterRoutes du fichier Global.asax, où routes est le paramètre de cette méthode de type RouteCollection. routes.maproute( "NomRoute", "UnControleur/UneAction/UnParametre", new // valeurs par défaut UnControleur = "Formation", UneAction = "Gestion", UnParametre = "" ); D'un répertoire Views, contenant toutes les vues. Lors de leur création, nous auront l'occasion de définir les caractéristiques suivantes : Le type de la vues (!!! Revoir les noms!!!) : vues pages (pages ASP.NET à part entière), vues de contenu (pages s'exécutant au sein d'une Master Page) et vues partielles (aussi appelée vues contrôles utilisateurs Web). S'il s'agit d'une vue typée ou non typée. Une vue typée permet de gérer un objet ou une collection d'objets d'un type particulier, par exemple un type du modèle de l'application. Le mode de gestion, permettant de définir le comportement de la vue en fonction de son rôle : "List" pour afficher le contenu d'une collection d'objets, "Detail" pour consulter l'ensemble des propriétés d'un objet, "Edit" pour modifier l'ensemble des propriétés d'un objet, Le répertoire Views contient un répertoire Shared, dont le rôle est particulier au sein de l'application. Comme son nom l'indique, il contient des vues qui partagées entre tous les contrôleurs de l'application. Lorsqu'un contrôleur souhaite exécuter une vue, le process de recherche d'une vue est le suivant : La vue (page ou contrôle utilisateur) est d'abord recherchée dans le répertoire ~/Views/<nomControleur>, où le nom du contrôleur est celui du contrôleur ayant demandé l'exécution de la vue. Si cette vue n'est pas trouvée, alors elle est recherchée dans le répertoire ~/Views/Shared. C.2. Préparation de l'application Le projet créé contient des fichiers que nous pouvons utiliser comme modèle pour accélérer le développement de notre application. Nous allons préparer notre projet, en supprimant les fichiers que nous n'utiliserons pas, et en indiquant ceux dont nous modifierons le contenu. Dans la copie-écran présentée ci-dessous, les Page 7 sur 41

fichiers encadrés en rouge sont ceux que nous supprimons, et les fichiers encadrés en vert sont ceux que nous modifierons : Ce projet va s'appuyer sur notre composant d'accès aux données LearningCompany_DAO, afin de pour lire et modifier les données de la base de données LearningCompany. Page 8 sur 41

Pour cette raison, nous ajoutons deux références dans notre projet, référençant les composants suivants : LearningCompany.dll. System.Data.Entity.dll. Il s'agit d'un composant du Framework.NET, permettant de pouvoir manipuler les entités exposées par notre composant d'accès aux données dans notre application. Pour le bon fonctionnement de notre composant d'accès aux données, nous devons définir dans le fichier de configuration de notre application ASP.NET MVC, la chaîne de connexion qu'il utilise. Conformément à ses spécifications (!!! A REVOIR, le contenu aussi!!!), il est elle doit être identifiée par le nom "CS_DataBase" : <connectionstrings> <add name="cs_database" connectionstring="metadata=res://*/learningcompany.csdl res://*/l earningcompany.ssdl res://*/learningcompany.msl;provider=system.d ata.sqlclient;provider connection string="data Source=localhost\sql2008;Initial Catalog=LearningCompany;Persist Security Info=True;User ID=userTest;Password=passwd;MultipleActiveResultSets=True"" providername="system.data.entityclient"/> </connectionstrings> C.3. Création de l'application C.3.a. Structure de l'application Voici la structure de l'application que nous allons réaliser : Page 9 sur 41

Ce design est composé de trois zones distinctes : Une zone "bandeau" contenant une présentation du centre de formation, et permettant à un utilisateur de se connecter afin de pouvoir utiliser des fonctionnalités avancées, de se déconnecter, et de modifier les informations le concernant. Une zone "fonctionnalités" permettant d'accéder à l'ensemble des fonctionnalités de l'application, à savoir : Accéder à la liste des formations par thème. Rechercher une formation à partir d'un libellé. Une zone "corps" affichant le contenu principal de la page, résultant des fonctionnalités, ou d'une action même au sein du corps. Pour implémenter cette structure, nous utiliserons une Page Maître, qui contiendra des panneaux (contrôle de type ContentPlaceHolder), dont le contenu du corps sera fourni lors de l'exécution des pages de contenu de l'application. Par défaut, notre application contient déjà une Page Maître, dont le nom est Site.Master, et contenue dans le répertoire /Views/Shared de l'application ASP.NET MVC. Nous modifions le code XHTML de cette page, de manière à créer trois divisions où chaque division correspond à une zone décrite ci-dessus : <body> <form runat="server"> <div id="bandeau"> </div> <div id="fonctionnalites"> </div> Page 10 sur 41

<div id="corps"> <asp:contentplaceholder ID="MainContent" runat="server" /> </div> </form> </body> Nous modifions aussi la feuille de style Site.css, afin de positionner et mettre en forme ces divisions : /******************************************************** *** Général. ********************************************************/ * padding:0px; margin:0px; /******************************************************** *** Zones de la Master Page. ********************************************************/ #Bandeau width:1000px; height:70px; background-color:#e7e7d9; #Fonctionnalites width:200px; height:800px; background-color:#bcb7ff; position:relative; float:left; padding:5px; #Corps width:750px; padding:5px; position:relative; float:left; /******************************************************** *** Liste de puces. ********************************************************/ ul padding-left:20px; /******************************************************** *** Sélecteurs d'éléments. ********************************************************/ h1 Page 11 sur 41

h2 padding-bottom:25px; text-align:center; margin-bottom:16px; text-align:center; /******************************************************** *** Alignements. ********************************************************/.CentrerConteneur margin-left: auto; margin-right: auto; Lors de l'exécution de la page de contenu WelCom.aspx, nous obtenons le résultat suivant : C.3.b. Réalisation du bandeau Le bandeau de notre application doit permettre à tout client de s'authentifier, afin de pouvoir modifier les informations le contenant ou pouvoir effectuer une demande d'informations complémentaire sur une formation (proposition de dates, formateur dispensant la formation, ). Pour ce faire, nous ajoutons dans le Page 12 sur 41

bandeau un lien hypertexte permettant de se connecter. Dès que l'utilisateur est connecté, alors le texte du lien doit être modifié, afin de l'inviter à se déconnecter, et un nouveau lien hypertexte intitulé "Mon compte" apparaît afin de lui permet de modifier les informations le concernant. Pour un utilisateur non connecté, le bandeau aura l'apparence suivante : Dans le cas inverse, l'utilisateur connecté verra le bandeau suivant : Nous aborderons l'implémentation de cette interface une fois que nous aurons implémenté la sécurité dans notre application. C.3.c. Réalisation de la zone des fonctionnalités Voici le design de la zone des fonctionnalités : La zone du libellé peut contenir tout ou partie d'un libellé d'une formation. Lorsque l'utilisateur clique sur le bouton intitulé "OK", alors la liste des formations correspondant dont le libellé contient le libellée recherché apparaissent dans le corps. Par exemple, si nous recherchons les formations contenant la chaîne de caractères "2007", le résultat suivant apparaît : Page 13 sur 41

Il en va de même si nous cliquons sur un thème, excepté que les formations affichées sont celles lui appartenant. C.4. Identification d'un client C.4.a. Mise en œuvre du service de gestion de la sécurité dans ASP.NET Avant de pouvoir déterminer quelles fonctionnalités de l'application auxquelles un client peut accéder, nous devons l'identifier au travers d'une fenêtre de connexion, dans laquelle il sera invité à saisir sa référence client et son mot de passe : En cas d'échec de l'identification, un message doit apparaître signalant que la référence client ou le mot de passe est incorrect. Pour implémenter l'identification des utilisateurs dans notre application, nous utiliserons le service d'authentification proposé par ASP.NET. Ce service peut être mis en œuvre avec un faible effort de développement. Il est possible de l'utiliser avec une base de données SQL Server proposée par Microsoft avec un schéma prédéfini, que nous pouvons créer avec l'outil aspnet_regsql (soit en ligne de commande, soit via un assistant graphique). Le Framework.NET fournit un provider nommé AspnetMembershipProvider permettant à ce service d'utiliser cette base de données. Il est aussi possible de définir notre propre base de données avec notre propre schéma. Ce sera le cas dans notre application. Pour ce faire, nous commercerons par créer un provider personnalisé permettant au service d'authentification d'utiliser notre base de données. Le schéma ci-dessous explicite le fonctionnement de ce service : Page 14 sur 41

La source de données sera la base de données de l'application. Le composant permettant d'accéder et gérer les données sera le composant LearningCompany_DAO. Etant donné que nous souhaitons authentifier les clients du centre de formation, l'entité utilisée au sein de ce composant d'accès aux données sera l'entité Client. Pour que le service de gestion de la sécurité puisse utiliser cette entité, nous devons créer un provider personnalisé, que nous déclarerons dans le fichier de configuration de l'application ASP.NET. C.4.b. Création du provider personnalisé Dans notre application ASP.NET MVC, nous créons un répertoire nommé Securite. Dans ce répertoire, nous créons une classe nommée OffreFormationMembershipProvider, qui spécialise la classe System.Web.Security.MembershipProvider du Framework.NET. Il s'agit d'une classe abstraite que toute classe constituant un provider personnalisé d'authentification doit hériter, et redéfinir les méthodes abstraites de cette classe. Pour les besoins de notre application nous redéfinirons uniquement la méthode ValidateUser, qui permet de savoir si une référence client et un mot de passe correspondent à un client enregistré dans notre base de données. Dans l'implémentation de cette méthode, nous utiliserons la méthode statique GetInstance de la classe Client. Si elle retourne un objet de type Client, alors cette méthode retournera la méthode true. Si elle retourne la valeur null, alors cette méthode retournera la méthode false. Page 15 sur 41

using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Security; using LearningCompany_DAO; namespace LearningCompany_OffreFormations.Securite public class OffreFormationMembershipProvider : MembershipProvider // Autres méthodes abstraites... public override bool ValidateUser(string areference, string amotdepasse) return Client.GetInstance(aReference, amotdepasse)!= null; Chacune des méthodes abstraites jouent un rôle particulier. Pour compléter cette classe vous devrez implémenter celles qui correspondent aux fonctionnalités du service d'authentification ASP.NET que vous souhaitez utiliser. C.4.c. Authentification d'un utilisateur et vérification des autorisations Voici un schéma présentant le processus d'identification d'un utilisateur souhaitant exécutée une page ASP.NET sécurisée : Page 16 sur 41

Un utilisateur demande l'accès à une page de l'application, en envoyant une requête HTTP au travers d'un navigateur Web. Le processus d'authentification commence. Il vérifie si la requête HTTP contient des preuves d'authentification (connues sous le nom de credentials en anglais), permettant d'identifier l'utilisateur ayant envoyée la requête. Si ces preuves ne sont pas trouvées ou insatisfaisantes, alors l'utilisateur est automatiquement rediriger vers la page d'identification. On remarque dans la barre d'adresse du navigateur la présence du paramètre nommé ReturnUrl, contenant l'url de la page vers laquelle l'utilisateur doit être redirigé si l'identification réussie et si les autorisations sont satisfaisantes. Tant que l'utilisateur ne saisit pas une référence client et un mot de passe correct, il reste sur la page d'identification. Dès qu'il saisit des informations correctes, le processus ASP.NET ajoute un cookie d'identification crypté à la réponse HTTP qui sera faite au client (action par défaut, qu'il est possible de paramétrer. Puis il vérifie que le compte identifié possède les autorisations nécessaires pour accéder à la page demande. Si c'est le cas, alors la page initialement demandée est exécutée, et le résultat de l'exécution est renvoyé au client. Le cas échéant, il est automatiquement renvoyé vers la même page d'identification. Lors de l'envoi des requêtes HTTP suivantes, le cookie d'identification est automatiquement attaché à la requête, afin que le serveur IIS puisse authentifier l'utilisateur. C.4.d. Enregistrement du provider personnalisé Pour que le service d'authentification puisse utiliser le provider que nous avons défini, nous devons l'enregistrer dans le fichier de configuration de l'application ASP.NET MVC. Dans ce fichier, nous nous positionnons sous l'élément System.Web et ajoutons les éléments XML suivants : <membership defaultprovider="custommembershipprovider"> <providers> <clear/> <add name="custommembershipprovider" type="learningcompany_offreformations.securite.offreformationmemb ershipprovider" /> </providers> </membership> Ces éléments XML permettent de déclarer une instance de notre provider OffreFormationMembershipProvider, que nous nommons CustomMembershipProvider. C.4.e. Définition du type d'authentification Pour utiliser le service de sécurité, toujours dans l'élément System.Web, nous ajoutons les lignes suivantes : <authentication mode="forms"> Page 17 sur 41

<forms loginurl="~/connexion/connecter" /> </authentication> Ces lignes permettent de déclarer que nous utilisons l'authentification par formulaire, ainsi que le l'url permettant d'accéder au formulaire de connexion. Cette URL est constituée du nom d'un contrôleur (Connexion) et d'une action (Connecter). Nous détaillerons cette écriture d'url ultérieurement dans ce chapitre. C.4.f. Connexion / déconnection des utilisateurs De manière à pouvoir enregistrer un client identifié et déconnecter un client, nous ajoutons dans le répertoire Securite de notre application, une classe que nous nommons FormsAuthenticationService. L'implémentation de cette classe est la suivante : public class FormsAuthenticationService public void Connecter(string areference, bool createpersistentcookie) FormsAuthentication.SetAuthCookie(aReference, createpersistentcookie); public void Deconnecter() FormsAuthentication.SignOut(); Le rôle de cette classe est d'assurer, au sein de notre application, un couplage faible entre le service d'authentification ASP.NET et les pages et contrôles utilisateurs qui l'utiliseront. Autrement dit, si nous utilisons un autre mécanisme d'authentification pour nos utilisateurs, nous limitons les modifications à apporter dans le code de l'application. Elle contient deux méthodes permettant de piloter le service d'authentification ASP.NET : La méthode Connecter permet de créer un cookie d'identification crypté qui sera automatiquement associé à la réponse renvoyée à l'utilisateur. Pour ce faire, nous appliquons la méthode statique SetAuthCookie de la classe FormsAuthentication, en lui fournissant la référence client permettant d'identifier le client connecté, et une valeur booléenne indiquant si le cookie est persistant (cookie utilisable par un même client au travers de différentes sessions ASP.NET). La méthode Deconnecter permet de déconnecter un utilisateur, en supprimant le cookie d'identification de la réponse renvoyée à l'utilisateur. Si l'utilisateur renvoie une nouvelle requête HTTP, il sera automatiquement redirigé vers la page d'authentification précédemment défini dans le fichier de configuration. Page 18 sur 41

C.4.g. Identification d'un utilisateur Dans le répertoire Securite, nous ajoutons une classe nommée ClientMembershipService. L'implémentation de cette classe est la suivante : public class ClientMembershipService private MembershipProvider Provider get; set; public ClientMembershipService() Provider = Membership.Provider; public bool CompteExiste(string areference, string amotdepasse) return Provider.ValidateUser(aReference, amotdepasse); Cette classe définit une propriété simplifiée nommé Provider, qui doit contenir une instance du provider créé par le service d'authentification ASP.NET, à partir des informations du provider Membership défini dans le fichier de configuration. Pour ce faire nous ajoutons un constructeur, qui initialise cette propriété via la propriété statique Provider de la classe System.Web.Security.Membership. Pour déterminer si un client existe dans notre base de données à partir d'une référence client et d'un mot de passe, nous créons une méthode acceptant en paramètre ces informations et retournant une valeur booléenne. Dans cette méthode nous exécutons la méthode ValidateUser sur la propriété Provider. Cette instruction permet d'exécuter la méthode de même nom de notre provider personnalisé. Ainsi dans cette méthode, retourne la valeur true si un client a été trouvé à partir de la référence et du mot de passe passé en paramètre, et false le cas échéant. C.4.h. Gestion des autorisations Une fois notre mécanisme d'authentification implémenté dans notre application, nous devons gérer les autorisations. Nous souhaitons que les utilisateurs soient authentifiés pour exécuter toutes les actions du contrôleur Client et l'action DemanderInfos du contrôleur Formation. Pour ce faire, nous appliquons la métadonnée System.Web.Mvc.AuthorizeAttribute au contrôleur Client et à l'action DemanderInfos du contrôleur Formation. Cette métadonnée, appliquée à un contrôleur, permet de s'assurer que tous les utilisateurs qui demandent l'exécution d'une action lui appartenant doivent être authentifiés. Appliqué à une action, cette règle s'applique uniquement sur l'action. => Plus d'actualité. A changer (juste une possibilité). Page 19 sur 41

C.4.i. Connexion / déconnection d'un utilisateur Dans le bandeau de l'application, le lien hypertexte permettant initialement de s'identifier est un lien à deux états. Un premier état permet à l'utilisateur de s'identifier ne l'est pas. Un second état permettant de demander à se déconnecter, le lien affichant le libellé Deconnexion. Lors de l'évolution de l'application, ce lien hypertexte peut être utilisé dans différentes pages, tout en conservant le même comportement. Afin d'implémenter une seule fois ce comportement dans notre application, nous ajoutons dans le répertoire ~/Views/Shared, un contrôle utilisateur MVC, que nous nommons AccesConnexion.ascx. Le code contenu dans ce contrôle présenté ci-dessous implémente cette fonctionnalité : <%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl" %> <% if (Request.IsAuthenticated) %> <%= Html.ActionLink("Déconnexion", "Deconnecter", "Connexion")%> <% else %> <%= Html.ActionLink("Connexion", "Connecter", "Connexion")%> <% %> La méthode ActionLink de l'objet Html (qui est une propriété héritée) génère un lien hypertexte, qui permet d'exécuter une action d'un contrôleur. Dans notre code, si l'utilisateur n'est pas authentifié, alors un lien hypertexte affichant le libellé Déconnexion et permettant d'exécuter l'action Deconnecter du contrôleur Connexion est affiché. Le cas échéant, un lien hypertexte affichant le libellé Connexion et permettant d'exécuter l'action Connecter du contrôleur Connexion est affiché. Pour utiliser ce contrôle dans le bandeau de l'application, nous affichons le code de la Master Page MVC Site.master, et nous positionnons dans la division correspondant au bandeau. Nous ajoutons alors le bloc de code suivant : <p> <% Html.RenderPartial("AccesConnexion"); %> </p> Ce bloc de code permet d'injecter dans la page maître le rendu du contrôle AccesConnexion.ascx lors de l'exécution de la page maître. Page 20 sur 41

D. Création des contrôleurs et des vues D.1. Présentation des contrôleurs Notre application sera constituée des contrôleurs suivants : Home : contrôleur par défaut de l'application, il permet au travers de son action Index, d'accéder à la page d'accueil de l'application ~/Home/Index.aspx. Client : permet d'agir sur un client, à savoir pouvoir afficher les informations le concernant et les modifier. Formation : permet de pouvoir accéder à un ensemble de formations, notamment lors de l'exécution des fonctionnalités de recherche des formations, et de fournir des informations les concernant. Connexion : permet de gérer la connexion / déconnexion d'un utilisateur, en utilisant le service d'authentification ASP.NET. Voici un schéma indiquant les interactions entre les vues et les contrôleurs de notre application : D.2. Implémentation du contrôleur Home Page 21 sur 41

Contenu dans le répertoire Controllers de l'application, le contrôleur Home est le contrôleur par défaut de notre application. Il est créé en même temps que l'application et est implémenté par la classe HomeController. Dans une application ASP.NET MVC, toute classe contrôleur est suffixée par Controller, et dérive de la classe System.Web.Mvc.Controller du Framework.NET. Il en sera de même pour tous les contrôleurs que nous créerons dans notre application. D.2.a. Implémentation de l'action Index() L'action Index est l'action par défaut de ce contrôleur, autrement dit qu'elle est exécutée si une route demande l'exécution du contrôleur Home sans préciser de contrôleur. Son rôle est de retourner la vue qui lui est affectée : [HandleError] public class HomeController : Controller public ActionResult Index() return View(); La métadonnée HandleError positionnée sur le contrôleur est utilisée pour faciliter la gestion des erreurs dans les contrôleurs. Cette action redirige l'utilisateur vers la vue ~/Views/Home/Index.aspx. Cette vue affiche un message de bienvenue : <%@ Page Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage" %> <asp:content ID="indexTitle" ContentPlaceHolderID="TitleContent" runat="server"> LearningCompany - Présentation </asp:content> <asp:content ID="indexContent" ContentPlaceHolderID="MainContent" runat="server"> <h2>bienvenue chez Learning Company</h2> <p> Veuillez rechercher des formations via leur libellé ou leur référence, ou cliquer sur un thème dans la liste ci-contre. </p> </asp:content> En exécutant l'url http://localhost:xxxx/, nous obtenons le résultat suivant (nous n'afficherons que le corps de la page) : Page 22 sur 41