Itération #1 : Créer l’application (C#)
par Microsoft
Dans la première itération, nous créons le Gestionnaire de contacts de la manière la plus simple possible. Nous ajoutons la prise en charge des opérations de base de données de base : Créer, Lire, Mettre à jour et Supprimer (CRUD).
Génération d’une application Gestion des contacts ASP.NET MVC (VB)
Dans cette série de tutoriels, nous créons une application gestion des contacts entière du début à la fin. L’application Gestionnaire de contacts vous permet de stocker des informations de contact (noms, numéros de téléphone et adresses e-mail) pour une liste de personnes.
Nous créons l’application sur plusieurs itérations. À chaque itération, nous améliorons progressivement l’application. L’objectif de cette approche d’itération multiple est de vous permettre de comprendre la raison de chaque modification.
Itération n°1 - Créer l’application. Dans la première itération, nous créons le Gestionnaire de contacts de la manière la plus simple possible. Nous ajoutons la prise en charge des opérations de base de données de base : Créer, Lire, Mettre à jour et Supprimer (CRUD).
Itération n° 2 : rendre l’application agréable. Dans cette itération, nous améliorons l’apparence de l’application en modifiant la ASP.NET vue MVC par défaut master page et la feuille de style en cascade.
Itération #3 - Ajouter la validation de formulaire. Dans la troisième itération, nous ajoutons la validation de formulaire de base. Nous empêchant les utilisateurs d’envoyer un formulaire sans remplir les champs de formulaire obligatoires. Nous validons également les adresses e-mail et les numéros de téléphone.
Itération n° 4 : rendre l’application faiblement couplée. Dans cette quatrième itération, nous nous appuyons sur plusieurs modèles de conception de logiciels pour faciliter la maintenance et la modification de l’application Gestionnaire de contacts. Par exemple, nous refactorisons notre application pour utiliser le modèle référentiel et le modèle d’injection de dépendances.
Itération n°5 - Créer des tests unitaires. Dans la cinquième itération, nous rendons notre application plus facile à gérer et à modifier en ajoutant des tests unitaires. Nous nous moquons de nos classes de modèle de données et nous créons des tests unitaires pour nos contrôleurs et notre logique de validation.
Itération n°6 - Utiliser le développement piloté par les tests. Dans cette sixième itération, nous ajoutons de nouvelles fonctionnalités à notre application en écrivant d’abord des tests unitaires et en écrivant du code sur les tests unitaires. Dans cette itération, nous ajoutons des groupes de contacts.
Itération n°7 - Ajouter la fonctionnalité Ajax. Dans la septième itération, nous améliorons la réactivité et les performances de notre application en ajoutant la prise en charge d’Ajax.
Cette itération
Dans cette première itération, nous créons l’application de base. L’objectif est de créer le Gestionnaire de contacts de la manière la plus rapide et la plus simple possible. Dans les itérations ultérieures, nous améliorons la conception de l’application.
L’application Gestionnaire de contacts est une application de base de données. Vous pouvez utiliser l’application pour créer des contacts, modifier des contacts existants et supprimer des contacts.
Dans cette itération, nous procédons comme suit :
- application MVC ASP.NET
- Créer une base de données pour stocker nos contacts
- Générer une classe de modèle pour notre base de données avec Microsoft Entity Framework
- Créer une action et une vue de contrôleur qui nous permettent de répertorier tous les contacts dans la base de données
- Créer des actions de contrôleur et une vue qui nous permet de créer un contact dans la base de données
- Créer des actions de contrôleur et une vue qui nous permet de modifier un contact existant dans la base de données
- Créer des actions de contrôleur et une vue qui nous permet de supprimer un contact existant dans la base de données
Composants logiciels requis
Dans ASP.NET applications MVC, visual Studio 2008 ou Visual Web Developer 2008 doit être installé sur votre ordinateur (Visual Web Developer est une version gratuite de Visual Studio qui n’inclut pas toutes les fonctionnalités avancées de Visual Studio). Vous pouvez télécharger la version d’évaluation de Visual Studio 2008 ou Visual Web Developer à partir de l’adresse suivante :
https://www.asp.net/downloads/essential/
Notes
Pour ASP.NET applications MVC avec Visual Web Developer, vous devez disposer de Visual Web Developer Service Pack 1. Sans Service Pack 1, vous ne pouvez pas créer de projets d’application web.
ASP.NET framework MVC. Vous pouvez télécharger l’infrastructure MVC ASP.NET à l’adresse suivante :
Dans ce didacticiel, nous utilisons Microsoft Entity Framework pour accéder à une base de données. Entity Framework est inclus dans .NET Framework 3.5 Service Pack 1. Vous pouvez télécharger ce Service Pack à partir de l’emplacement suivant :
https://www.microsoft.com/download/details.aspx?id=22& desc=dotnet35
En guise d’alternative à l’exécution de chacun de ces téléchargements un par un, vous pouvez tirer parti du programme d’installation de plateforme web (WEB PI). Vous pouvez télécharger l’ip web à partir de l’adresse suivante :
https://www.asp.net/downloads/essential/
ASP.NET projet MVC
ASP.NET projet d’application web MVC. Lancez Visual Studio et sélectionnez l’option de menu Fichier, Nouveau projet. La boîte de dialogue Nouveau projet s’affiche (voir figure 1). Sélectionnez le type de projet web et le modèle d’application web MVC ASP.NET . Nommez votre nouveau projet ContactManager , puis cliquez sur le bouton OK.
Vérifiez que .NET Framework 3.5 est sélectionné dans la liste déroulante située en haut à droite de la boîte de dialogue Nouveau projet . Sinon, le modèle d’application web MVC ASP.NET n’apparaîtra pas.
Figure 01 : Boîte de dialogue Nouveau projet (Cliquez pour afficher l’image en taille réelle)
ASP.NET application MVC, la boîte de dialogue Créer un projet de test unitaire s’affiche. Vous pouvez utiliser cette boîte de dialogue pour indiquer que vous souhaitez créer et ajouter un projet de test unitaire à votre solution lorsque vous créez votre application MVC ASP.NET. Bien que nous ne créons pas de tests unitaires dans cette itération, vous devez sélectionner l’option Oui, créer un projet de test unitaire, car nous prévoyons d’ajouter des tests unitaires dans une itération ultérieure. L’ajout d’un projet test lorsque vous créez un projet MVC ASP.NET est beaucoup plus facile que l’ajout d’un projet test après la création du projet MVC ASP.NET.
Notes
Étant donné que Visual Web Developer ne prend pas en charge les projets de test, vous n’obtenez pas la boîte de dialogue Créer un projet de test unitaire lors de l’utilisation de Visual Web Developer.
Figure 02 : Boîte de dialogue Créer un projet de test unitaire (cliquer pour afficher une image en taille réelle)
ASP.NET application MVC s’affiche dans la fenêtre Explorateur de solutions Visual Studio (voir figure 3). Si vous ne voyez pas la fenêtre Explorateur de solutions, vous pouvez ouvrir cette fenêtre en sélectionnant l’option de menu Afficher, Explorateur de solutions. Notez que la solution contient deux projets : le ASP.NET projet MVC et le projet test. Le ASP.NET projet MVC est nommé ContactManager et le projet de test est nommé ContactManager.Tests.
Figure 03 : fenêtre Explorateur de solutions (cliquer pour afficher l’image en taille réelle)
Suppression des exemples de fichiers de projet
Le modèle de projet MVC ASP.NET inclut des exemples de fichiers pour les contrôleurs et les vues. Avant de créer une application MVC ASP.NET, vous devez supprimer ces fichiers. Vous pouvez supprimer des fichiers et des dossiers dans la fenêtre Explorateur de solutions en cliquant avec le bouton droit sur un fichier ou un dossier et en sélectionnant l’option de menu Supprimer.
Vous devez supprimer les fichiers suivants du projet MVC ASP.NET :
\Contrôleurs\HomeController.cs
\Views\Home\About.aspx
\Views\Home\Index.aspx
Vous devez également supprimer le fichier suivant du projet de test :
\Contrôleurs\HomeControllerTest.cs
Création de la base de données
L’application Gestionnaire de contacts est une application web pilotée par une base de données. Nous utilisons une base de données pour stocker les informations de contact.
Le ASP.NET framework MVC avec n’importe quelle base de données moderne, y compris les bases de données Microsoft SQL Server, Oracle, MySQL et IBM DB2. Dans ce tutoriel, nous utilisons une base de données Microsoft SQL Server. Lorsque vous installez Visual Studio, vous avez la possibilité d’installer Microsoft SQL Server Express qui est une version gratuite de la base de données Microsoft SQL Server.
Créez une base de données en cliquant avec le bouton droit sur le dossier App_Data dans la fenêtre Explorateur de solutions et en sélectionnant l’option de menu Ajouter, Nouvel élément. Dans la boîte de dialogue Ajouter un nouvel élément, sélectionnez la catégorie Données et le modèle Base de données SQL Server (voir la figure 4). Nommez la nouvelle base de données ContactManagerDB.mdf, puis cliquez sur le bouton OK.
Figure 04 : Création d’une base de données Microsoft SQL Server Express (cliquer pour afficher l’image en taille réelle)
Une fois la base de données créée, la base de données apparaît dans le dossier App_Data dans la fenêtre Explorateur de solutions. Double-cliquez sur le fichier ContactManager.mdf pour ouvrir la fenêtre Server Explorer et vous connecter à la base de données.
Notes
La fenêtre Server Explorer est appelée fenêtre Explorer base de données dans le cas de Microsoft Visual Web Developer.
Vous pouvez utiliser la fenêtre Server Explorer pour créer des objets de base de données tels que des tables de base de données, des vues, des déclencheurs et des procédures stockées. Cliquez avec le bouton droit sur le dossier Tables et sélectionnez l’option de menu Ajouter une nouvelle table. La table de base de données Designer s’affiche (voir la figure 5).
Figure 05 : La table de base de données Designer (cliquer pour afficher l’image en taille réelle)
Nous devons créer une table qui contient les colonnes suivantes :
Nom de la colonne | Type de données | Null autorisé |
---|---|---|
Id | int | false |
FirstName | nvarchar(50) | false |
LastName | nvarchar(50) | false |
Téléphone | nvarchar(50) | false |
Courrier | nvarchar(255) | false |
La première colonne, la colonne Id, est spéciale. Vous devez marquer la colonne Id en tant que colonne Identité et colonne Clé primaire. Vous indiquez qu’une colonne est une colonne d’identité en développant Propriétés de colonne (regardez le bas de la figure 6) et en faisant défiler jusqu’à la propriété Identity Specification. Définissez la propriété (Is Identity) sur la valeur Oui.
Vous marquez une colonne comme colonne clé primaire en sélectionnant la colonne et en cliquant sur le bouton avec l’icône d’une clé. Une fois qu’une colonne est marquée comme colonne clé primaire, une icône d’une clé apparaît en regard de la colonne (voir la figure 6).
Une fois la création de la table terminée, cliquez sur le bouton Enregistrer (bouton avec une icône de disquette) pour enregistrer la nouvelle table. Donnez à votre nouvelle table le nom Contacts.
Une fois la table de base de données contacts créée, vous devez ajouter des enregistrements à la table. Cliquez avec le bouton droit sur la table Contacts dans la fenêtre Server Explorer et sélectionnez l’option de menu Afficher les données de table. Entrez un ou plusieurs contacts dans la grille qui s’affiche.
Création du modèle de données
L’application MVC ASP.NET se compose de modèles, de vues et de contrôleurs. Nous commençons par créer une classe Model qui représente la table Contacts que nous avons créée dans la section précédente.
Dans ce tutoriel, nous utilisons Microsoft Entity Framework pour générer automatiquement une classe de modèle à partir de la base de données.
Notes
Le ASP.NET framework MVC n’est pas lié à Microsoft Entity Framework de quelque manière que ce soit. Vous pouvez utiliser ASP.NET MVC avec d’autres technologies d’accès aux bases de données, notamment NHibernate, LINQ to SQL ou ADO.NET.
Pour créer les classes de modèle de données, procédez comme suit :
- Cliquez avec le bouton droit sur le dossier Models dans la fenêtre Explorateur de solutions, puis sélectionnez Ajouter, Nouvel élément. La boîte de dialogue Ajouter un nouvel élément s’affiche (voir la figure 6).
- Sélectionnez la catégorie Données et le modèle ADO.NET Entity Data Model . Nommez votre modèle de données ContactManagerModel.edmx , puis cliquez sur le bouton Ajouter . L’Assistant Entity Data Model s’affiche (voir la figure 7).
- À l’étape Choisir le contenu du modèle , sélectionnez Générer à partir de la base de données (voir la figure 7).
- Dans l’étape Choisir votre connexion de données , sélectionnez la base de données ContactManagerDB.mdf et entrez le nom ContactManagerDBEntities pour les paramètres de connexion d’entité (voir la figure 8).
- À l’étape Choisir vos objets de base de données , cochez la case Tables (voir la figure 9). Le modèle de données inclut toutes les tables contenues dans votre base de données (il n’y en a qu’une seule, la table Contacts). Entrez l’espace de noms Modèles. Cliquez sur le bouton Terminer pour terminer l’Assistant.
Figure 06 : Boîte de dialogue Ajouter un nouvel élément (cliquer pour afficher l’image en taille réelle)
Figure 07 : Choisir le contenu du modèle (cliquer pour afficher l’image en taille réelle)
Figure 08 : Choisir votre connexion de données (cliquer pour afficher l’image en taille réelle)
Figure 09 : Choisir vos objets de base de données (cliquer pour afficher l’image en taille réelle)
Une fois l’Assistant Modèle de données d’entité terminé, le Designer Entity Data Model s’affiche. Le concepteur affiche une classe qui correspond à chaque table modélisée. Vous devez voir une classe nommée Contacts.
L’Assistant Entity Data Model génère des noms de classes basés sur les noms de tables de base de données. Vous devez presque toujours modifier le nom de la classe générée par l’Assistant. Cliquez avec le bouton droit sur la classe Contacts dans le concepteur et sélectionnez l’option de menu Renommer. Remplacez le nom de la classe Contacts (pluriel) par Contact (singulier). Une fois que vous avez modifié le nom de la classe, la classe doit apparaître comme figure 10.
Figure 10 : Classe Contact (cliquer pour afficher l’image en taille réelle)
À ce stade, nous avons créé notre modèle de base de données. Nous pouvons utiliser la classe Contact pour représenter un enregistrement de contact particulier dans notre base de données.
Création du contrôleur de base
L’étape suivante consiste à créer notre contrôleur d’accueil. Le contrôleur home est le contrôleur par défaut appelé dans une application MVC ASP.NET.
Créez la classe de contrôleur home en cliquant avec le bouton droit sur le dossier Contrôleurs dans la fenêtre Explorateur de solutions et en sélectionnant l’option de menu Ajouter, Contrôleur (voir figure 11). Notez la case à cocher Intitulée Ajouter des méthodes d’action pour les scénarios Créer, Mettre à jour et Détails. Vérifiez que cette case à cocher est cochée avant de cliquer sur le bouton Ajouter .
Figure 11 : Ajout du contrôleur d’accueil (cliquer pour afficher l’image en taille réelle)
Lorsque vous créez le contrôleur d’accueil, vous obtenez la classe dans la liste 1.
Listing 1 - Contrôleurs\HomeController.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.Web.Mvc.Ajax;
namespace ContactManager.Controllers
{
public class HomeController : Controller
{
//
// GET: /Home/
public ActionResult Index()
{
return View();
}
//
// GET: /Home/Details/5
public ActionResult Details(int id)
{
return View();
}
//
// GET: /Home/Create
public ActionResult Create()
{
return View();
}
//
// POST: /Home/Create
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Create(FormCollection collection)
{
try
{
// TODO: Add insert logic here
return RedirectToAction("Index");
}
catch
{
return View();
}
}
//
// GET: /Home/Edit/5
public ActionResult Edit(int id)
{
return View();
}
//
// POST: /Home/Edit/5
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Edit(int id, FormCollection collection)
{
try
{
// TODO: Add update logic here
return RedirectToAction("Index");
}
catch
{
return View();
}
}
}
}
Liste des contacts
Pour afficher les enregistrements dans la table de base de données Contacts, nous devons créer une action Index() et une vue Index.
Le contrôleur d’accueil contient déjà une action Index(). Nous devons modifier cette méthode pour qu’elle ressemble à la liste 2.
Liste 2 - Contrôleurs\HomeController.cs
public class HomeController : Controller
{
private ContactManagerDBEntities _entities = new ContactManagerDBEntities();
//
// GET: /Home/
public ActionResult Index()
{
return View(_entities.ContactSet.ToList());
}
…
Notez que la classe de contrôleur d’accueil de la liste 2 contient un champ privé nommé _entities. Le champ _entities représente les entités du modèle de données. Nous utilisons le champ _entities pour communiquer avec la base de données.
La méthode Index() retourne une vue qui représente tous les contacts de la table de base de données Contacts. Expression _entities. ContactSet.ToList() retourne la liste des contacts sous forme de liste générique.
Maintenant que nous avons créé le contrôleur d’index, nous devons ensuite créer la vue Index. Avant de créer la vue Index, compilez votre application en sélectionnant l’option de menu Générer, Générer la solution. Vous devez toujours compiler votre projet avant d’ajouter une vue afin que la liste des classes de modèle s’affiche dans la boîte de dialogue Ajouter une vue .
Vous créez la vue Index en cliquant avec le bouton droit sur la méthode Index() et en sélectionnant l’option de menu Ajouter une vue (voir figure 12). La sélection de cette option de menu ouvre la boîte de dialogue Ajouter un affichage (voir figure 13).
Figure 12 : Ajout de la vue Index (Cliquer pour afficher l’image en taille réelle)
Dans la boîte de dialogue Ajouter une vue, case activée la case à cocher Créer une vue fortement typée. Sélectionnez la classe de données View ContactManager.Models.Contact et la liste Afficher le contenu. La sélection de ces options génère une vue qui affiche une liste d’enregistrements de contact.
Figure 13 : Boîte de dialogue Ajouter une vue (cliquer pour afficher une image en taille réelle)
Lorsque vous cliquez sur le bouton Ajouter , la vue Index de la liste 3 est générée. Notez la <directive %@ Page %> qui s’affiche en haut du fichier. La vue Index hérite de la classe ContactManager.Models.Contact>> ViewPage<IEnumerable<. En d’autres termes, la classe Model dans la vue représente une liste d’entités Contact.
Le corps de la vue Index contient une boucle foreach qui itère à travers chacun des contacts représentés par la classe Model. La valeur de chaque propriété de la classe Contact s’affiche dans une table HTML.
Listing 3 - Views\Home\Index.aspx (non modifié)
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<IEnumerable<ContactManager.Models.Contact>>" %>
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="server">
<title>Index</title>
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
<h2>Index</h2>
<table>
<tr>
<th></th>
<th>
Id
</th>
<th>
FirstName
</th>
<th>
LastName
</th>
<th>
Phone
</th>
<th>
Email
</th>
</tr>
<% foreach (var item in Model) { %>
<tr>
<td>
<%= Html.ActionLink("Edit", "Edit", new { id=item.Id }) %> |
<%= Html.ActionLink("Details", "Details", new { id=item.Id })%>
</td>
<td>
<%= Html.Encode(item.Id) %>
</td>
<td>
<%= Html.Encode(item.FirstName) %>
</td>
<td>
<%= Html.Encode(item.LastName) %>
</td>
<td>
<%= Html.Encode(item.Phone) %>
</td>
<td>
<%= Html.Encode(item.Email) %>
</td>
</tr>
<% } %>
</table>
<p>
<%= Html.ActionLink("Create New", "Create") %>
</p>
</asp:Content>
Nous devons apporter une modification à la vue Index. Étant donné que nous ne créons pas d’affichage Détails, nous pouvons supprimer le lien Détails. Recherchez et supprimez le code suivant de la vue Index :
{ id=item. ID })%>
Après avoir modifié la vue Index, vous pouvez exécuter l’application Gestionnaire de contacts. Sélectionnez l’option de menu Déboguer, Démarrer le débogage ou appuyez simplement sur F5. La première fois que vous exécutez l’application, vous obtenez la boîte de dialogue dans la figure 14. Sélectionnez l’option Modifier le fichier Web.config pour activer le débogage , puis cliquez sur le bouton OK.
Figure 14 : Activation du débogage (cliquer pour afficher l’image en taille réelle)
La vue Index est retournée par défaut. Cette vue répertorie toutes les données de la table de base de données Contacts (voir figure 15).
Figure 15 : Affichage Index (cliquer pour afficher l’image en taille réelle)
Notez que la vue Index comprend un lien intitulé Créer nouveau en bas de la vue. Dans la section suivante, vous allez apprendre à créer des contacts.
Création de nouveaux contacts
Pour permettre aux utilisateurs de créer de nouveaux contacts, nous devons ajouter deux actions Create() au contrôleur d’accueil. Nous devons créer une action Créer() qui retourne un formulaire HTML pour créer un contact. Nous devons créer une deuxième action Create() qui effectue l’insertion de base de données réelle du nouveau contact.
Les nouvelles méthodes Create() que nous devons ajouter au contrôleur d’accueil sont contenues dans la liste 4.
Liste 4 - Contrôleurs\HomeController.cs (avec les méthodes Create)
//
// GET: /Home/Create
public ActionResult Create()
{
return View();
}
//
// POST: /Home/Create
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Create([Bind(Exclude = "Id")] Contact contactToCreate)
{
if (!ModelState.IsValid)
return View();
try
{
_entities.AddToContactSet(contactToCreate);
_entities.SaveChanges();
return RedirectToAction("Index");
}
catch
{
return View();
}
}
La première méthode Create() peut être appelée avec un HTTP GET tandis que la deuxième méthode Create() peut être appelée uniquement par un HTTP POST. En d’autres termes, la deuxième méthode Create() ne peut être appelée que lors de la publication d’un formulaire HTML. La première méthode Create() retourne simplement une vue qui contient le formulaire HTML permettant de créer un contact. La deuxième méthode Create() est beaucoup plus intéressante : elle ajoute le nouveau contact à la base de données.
Notez que la deuxième méthode Create() a été modifiée pour accepter un instance de la classe Contact. Les valeurs de formulaire publiées à partir du formulaire HTML sont automatiquement liées à cette classe Contact par l’infrastructure MVC ASP.NET. Chaque champ de formulaire du formulaire HTML Create est affecté à une propriété du paramètre Contact.
Notez que le paramètre Contact est décoré avec un attribut [Bind]. L’attribut [Bind] est utilisé pour exclure la propriété Id de contact de la liaison. Étant donné que la propriété Id représente une propriété Identity, nous ne voulons pas définir la propriété Id.
Dans le corps de la méthode Create(), Entity Framework est utilisé pour insérer le nouveau contact dans la base de données. Le nouveau Contact est ajouté à l’ensemble existant de Contacts et la méthode SaveChanges() est appelée pour renvoyer ces modifications à la base de données sous-jacente.
Vous pouvez générer un formulaire HTML pour créer des contacts en cliquant avec le bouton droit sur l’une des deux méthodes Create() et en sélectionnant l’option de menu Ajouter un affichage (voir figure 16).
Figure 16 : Ajout de la vue Créer (Cliquer pour afficher l’image en taille réelle)
Dans la boîte de dialogue Ajouter une vue , sélectionnez la classe ContactManager.Models.Contact et l’option Créer pour afficher le contenu (voir figure 17). Lorsque vous cliquez sur le bouton Ajouter , une vue Créer est générée automatiquement.
Figure 17 : Voir une page exploser (cliquer pour afficher l’image en taille réelle)
La vue Créer contient des champs de formulaire pour chacune des propriétés de la classe Contact. Le code de la vue Créer est inclus dans la liste 5.
Listing 5 - Views\Home\Create.aspx
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<ContactManager.Models.Contact>" %>
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="server">
<title>Create</title>
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
<h2>Create</h2>
<%= Html.ValidationSummary() %>
<% using (Html.BeginForm()) {%>
<fieldset>
<legend>Fields</legend>
<p>
<label for="FirstName">FirstName:</label>
<%= Html.TextBox("FirstName") %>
<%= Html.ValidationMessage("FirstName", "*") %>
</p>
<p>
<label for="LastName">LastName:</label>
<%= Html.TextBox("LastName") %>
<%= Html.ValidationMessage("LastName", "*") %>
</p>
<p>
<label for="Phone">Phone:</label>
<%= Html.TextBox("Phone") %>
<%= Html.ValidationMessage("Phone", "*") %>
</p>
<p>
<label for="Email">Email:</label>
<%= Html.TextBox("Email") %>
<%= Html.ValidationMessage("Email", "*") %>
</p>
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
<% } %>
<div>
<%=Html.ActionLink("Back to List", "Index") %>
</div>
</asp:Content>
Après avoir modifié les méthodes Create() et ajouté la vue Créer, vous pouvez exécuter l’application Gestionnaire de contacts et créer de nouveaux contacts. Cliquez sur le lien Créer qui s’affiche en mode Index pour accéder à la vue Créer. Vous devez voir la vue dans la figure 18.
Figure 18 : Mode Créer (cliquer pour afficher l’image en taille réelle)
Modification des contacts
L’ajout de la fonctionnalité de modification d’un enregistrement de contact est très similaire à l’ajout de la fonctionnalité de création d’enregistrements de contact. Tout d’abord, nous devons ajouter deux nouvelles méthodes Edit à la classe de contrôleur d’accueil. Ces nouvelles méthodes Edit() sont contenues dans listing 6.
Liste 6 - Contrôleurs\HomeController.cs (avec les méthodes Edit)
//
// GET: /Home/Edit/5
public ActionResult Edit(int id)
{
var contactToEdit = (from c in _entities.ContactSet
where c.Id == id
select c).FirstOrDefault();
return View(contactToEdit);
}
//
// POST: /Home/Edit/5
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Edit(Contact contactToEdit)
{
if (!ModelState.IsValid)
return View();
try
{
var originalContact = (from c in _entities.ContactSet
where c.Id == contactToEdit.Id
select c).FirstOrDefault();
_entities.ApplyPropertyChanges(originalContact.EntityKey.EntitySetName, contactToEdit);
_entities.SaveChanges();
return RedirectToAction("Index");
}
catch
{
return View();
}
}
}
La première méthode Edit() est appelée par une opération HTTP GET. Un paramètre Id est passé à cette méthode qui représente l’ID de l’enregistrement de contact en cours de modification. Entity Framework est utilisé pour récupérer un contact qui correspond à l’ID. Une vue qui contient un formulaire HTML pour modifier un enregistrement est retournée.
La deuxième méthode Edit() effectue la mise à jour réelle de la base de données. Cette méthode accepte un instance de la classe Contact comme paramètre. L’infrastructure MVC ASP.NET lie automatiquement les champs de formulaire du formulaire Modifier à cette classe. Notez que vous n’incluez pas l’attribut[Bind] lors de la modification d’un Contact (nous avons besoin de la valeur de la propriété Id).
Entity Framework est utilisé pour enregistrer le contact modifié dans la base de données. Le contact d’origine doit d’abord être récupéré à partir de la base de données. Ensuite, la méthode Entity Framework ApplyPropertyChanges() est appelée pour enregistrer les modifications apportées au Contact. Enfin, la méthode Entity Framework SaveChanges() est appelée pour conserver les modifications apportées à la base de données sous-jacente.
Vous pouvez générer l’affichage qui contient le formulaire Modifier en cliquant avec le bouton droit sur la méthode Edit() et en sélectionnant l’option de menu Ajouter un affichage. Dans la boîte de dialogue Ajouter une vue, sélectionnez la classe ContactManager.Models.Contact et le contenu de la vue Modifier (voir figure 19).
Figure 19 : Ajout d’un mode Édition (Cliquer pour afficher une image de taille réelle)
Lorsque vous cliquez sur le bouton Ajouter, une nouvelle vue Modifier est générée automatiquement. Le formulaire HTML généré contient des champs qui correspondent à chacune des propriétés de la classe Contact (voir Listing 7).
Listing 7 - Views\Home\Edit.aspx
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<ContactManager.Models.Contact>" %>
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="server">
<title>Edit</title>
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
<h2>Edit</h2>
<%= Html.ValidationSummary() %>
<% using (Html.BeginForm()) {%>
<fieldset>
<legend>Fields</legend>
<p>
<label for="FirstName">FirstName:</label>
<%= Html.TextBox("FirstName") %>
<%= Html.ValidationMessage("FirstName", "*") %>
</p>
<p>
<label for="LastName">LastName:</label>
<%= Html.TextBox("LastName") %>
<%= Html.ValidationMessage("LastName", "*") %>
</p>
<p>
<label for="Phone">Phone:</label>
<%= Html.TextBox("Phone") %>
<%= Html.ValidationMessage("Phone", "*") %>
</p>
<p>
<label for="Email">Email:</label>
<%= Html.TextBox("Email") %>
<%= Html.ValidationMessage("Email", "*") %>
</p>
<p>
<input type="submit" value="Save" />
</p>
</fieldset>
<% } %>
<div>
<%=Html.ActionLink("Back to List", "Index") %>
</div>
</asp:Content>
Suppression de contacts
Si vous souhaitez supprimer des contacts, vous devez ajouter deux actions Delete() à la classe home controller. La première action Supprimer() affiche un formulaire de confirmation de suppression. La deuxième action Supprimer() effectue la suppression réelle.
Notes
Plus tard, dans Itération #7, nous modifions le Gestionnaire de contacts afin qu’il prenne en charge une suppression Ajax en une étape.
Les deux nouvelles méthodes Delete() sont contenues dans listing 8.
Liste 8 - Contrôleurs\HomeController.cs (méthodes Delete)
//
// GET: /Home/Delete/5
public ActionResult Delete(int id)
{
var contactToDelete = (from c in _entities.ContactSet
where c.Id == id
select c).FirstOrDefault();
return View(contactToDelete);
}
//
// POST: /Home/Delete/5
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Delete(Contact contactToDelete)
{
try
{
var originalContact = (from c in _entities.ContactSet
where c.Id == contactToDelete.Id
select c).FirstOrDefault();
_entities.DeleteObject(originalContact);
_entities.SaveChanges();
return RedirectToAction("Index");
}
catch
{
return View();
}
}
La première méthode Delete() retourne un formulaire de confirmation pour la suppression d’un enregistrement de contact de la base de données (voir figure 20). La deuxième méthode Delete() effectue l’opération de suppression réelle sur la base de données. Une fois le contact d’origine récupéré à partir de la base de données, les méthodes Entity Framework DeleteObject() et SaveChanges() sont appelées pour effectuer la suppression de la base de données.
Figure 20 : Affichage de confirmation de suppression (cliquer pour afficher l’image en taille réelle)
Nous devons modifier la vue Index afin qu’elle contienne un lien pour supprimer les enregistrements de contact (voir figure 21). Vous devez ajouter le code suivant à la même cellule de table qui contient le lien Modifier :
Html.ActionLink( { id=item. Id }) %>
Figure 21 : Affichage d’index avec le lien Modifier (Cliquer pour afficher l’image en taille réelle)
Ensuite, nous devons créer la vue de confirmation de suppression. Cliquez avec le bouton droit sur la méthode Delete() dans la classe du contrôleur d’accueil et sélectionnez l’option de menu Ajouter une vue. La boîte de dialogue Ajouter une vue s’affiche (voir figure 22).
Contrairement aux vues Liste, Créer et Modifier, la boîte de dialogue Ajouter un affichage ne contient pas d’option permettant de créer un affichage Supprimer. Sélectionnez plutôt la classe de données ContactManager.Models.Contact et le contenu de la vue vide . La sélection de l’option Vider le contenu d’affichage nous oblige à créer l’affichage nous-mêmes.
Figure 22 : Ajout de la vue de confirmation de suppression (cliquer pour afficher l’image en taille réelle)
Le contenu de la vue Supprimer se trouve dans la liste 9. Cette vue contient un formulaire qui confirme si un contact particulier doit ou non être supprimé (voir figure 21).
Listing 9 - Views\Home\Delete.aspx
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<ContactManager.Models.Contact>" %>
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="server">
<title>Delete</title>
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
<h2>Delete</h2>
<p>
Are you sure that you want to delete the entry for
<%= Model.FirstName %> <%= Model.LastName %>?
</p>
<% using (Html.BeginForm(new { Id = Model.Id }))
{ %>
<p>
<input type="submit" value="Delete" />
</p>
<% } %>
<div>
<%=Html.ActionLink("Back to List", "Index") %>
</div>
</asp:Content>
Modification du nom du contrôleur par défaut
Il peut vous déranger que le nom de notre classe de contrôleur pour l’utilisation des contacts soit nommé classe HomeController. Le contrôleur ne doit-il pas être nommé ContactController ?
Ce problème est assez facile à résoudre. Tout d’abord, nous devons refactoriser le nom du contrôleur d’accueil. Ouvrez la classe HomeController dans le Rédacteur Visual Studio Code, cliquez avec le bouton droit sur le nom de la classe et sélectionnez l’option de menu Refactoriser, Renommer. La sélection de cette option de menu ouvre la boîte de dialogue Renommer.
Figure 23 : Refactorisation d’un nom de contrôleur (cliquer pour afficher l’image en taille réelle)
Figure 24 : Utilisation de la boîte de dialogue Renommer (cliquer pour afficher l’image en taille réelle)
Si vous renommez votre classe de contrôleur, Visual Studio met également à jour le nom du dossier dans le dossier Views. Visual Studio renomme le dossier \Views\Home en dossier \Views\Contact.
Une fois cette modification effectuée, votre application n’aura plus de contrôleur de base. Lorsque vous exécutez votre application, vous obtenez la page d’erreur dans la figure 25.
Figure 25 : Aucun contrôleur par défaut (cliquer pour afficher l’image en taille réelle)
Nous devons mettre à jour l’itinéraire par défaut dans le fichier Global.asax pour utiliser le contrôleur de contacts au lieu du contrôleur d’accueil. Ouvrez le fichier Global.asax et modifiez le contrôleur par défaut utilisé par la route par défaut (voir Listing 10).
Référencement 10 - Global.asax.cs
using System.Web.Mvc;
using System.Web.Routing;
namespace ContactManager
{
public class MvcApplication : System.Web.HttpApplication
{
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
routes.MapRoute(
"Default", // Route name
"{controller}/{action}/{id}", // URL with parameters
new { controller = "Contact", action = "Index", id = "" } // Parameter defaults
);
}
protected void Application_Start()
{
RegisterRoutes(RouteTable.Routes);
}
}
}
Une fois ces modifications effectuées, le Gestionnaire de contacts s’exécute correctement. À présent, il utilise la classe contrôleur de contact comme contrôleur par défaut.
Résumé
Dans cette première itération, nous avons créé une application Contact Manager de base de la manière la plus rapide possible. Nous avons tiré parti de Visual Studio pour générer automatiquement le code initial de nos contrôleurs et vues. Nous avons également tiré parti d’Entity Framework pour générer automatiquement nos classes de modèle de base de données.
Actuellement, nous pouvons répertorier, créer, modifier et supprimer des enregistrements de contact avec l’application Gestionnaire de contacts. En d’autres termes, nous pouvons effectuer toutes les opérations de base de données de base requises par une application web pilotée par une base de données.
Malheureusement, notre application rencontre des problèmes. Tout d’abord et j’hésite à l’admettre, l’application Gestionnaire de contacts n’est pas l’application la plus attrayante. Il a besoin d’un travail de conception. Dans l’itération suivante, nous allons voir comment modifier l’affichage par défaut master page et la feuille de style en cascade pour améliorer l’apparence de l’application.
Deuxièmement, nous n’avons implémenté aucune validation de formulaire. Par exemple, rien ne vous empêche d’envoyer le formulaire Créer un contact sans entrer de valeurs pour l’un des champs de formulaire. En outre, vous pouvez entrer des numéros de téléphone et des adresses e-mail non valides. Nous commençons à nous attaquer au problème de la validation de formulaire dans l’itération #3.
Enfin, et surtout, l’itération actuelle de l’application Gestionnaire de contacts ne peut pas être facilement modifiée ou gérée. Par exemple, la logique d’accès à la base de données est intégrée directement dans les actions du contrôleur. Cela signifie que nous ne pouvons pas modifier notre code d’accès aux données sans modifier nos contrôleurs. Dans les itérations ultérieures, nous explorons les modèles de conception de logiciels que nous pouvons implémenter pour rendre le Gestionnaire de contacts plus résilient aux changements.