Depuis l'avènement des NuGet packages et des autre tools qui entourent Visual Studio, sans lesquels il n'est pas possible de faire quoi que se soit, je trouve que le développement ASP.NET tient de la magie. Comme je n'ai pas froid au yeux et que je suis un peu magicien moi même, à mes heures perdues, je me lance.
J'ai trouvé ceci : ASP.NET MVC 4 – CRUD operations Entity Framework (8 steps to create your site).
Mais moi, je voudrais utiliser :
Visual Studio 2010, avec ASP.NET MVC 4, ADO Entity Framework 5.x et NuGet pour faire un CRUD (create/read/update/delete) de données structurées dans une BD SqlServer.
Est-ce que c'est possible ?
Installation de la plateforme de développement
Tout passe par la gestion des extensions et la configuration des Packages NuGet :Gestion des Extensions |
Extensions installées par NuGet |
NuGet Package Management et EF 5.x DBContext Generator for C# sont les deux extensions nécessaires à la réalisation de mon CRUD.
EF 5.x DBContext Generator for C# va me permettre de créer le modèle de données que j'utiliserai dans mon application ASP.NET MVC4.
Création de ma nouvelle Application MVC4
Après avoir installé le package MVC4 pour Visual Studio que j'ai téléchargé Ici.
Il ne me reste plus qu'à créer mon premier projet :
Création d'une application ASP.NET MVC 4 avec Visual Studio |
La structure du projet est la suivante :
Structure d'un projet ASP.NET MVC4 |
C'est déjà un projet assez conséquent avec déjà quelques formulaires concernant la création et la gestion des contacts et des utilisateurs de l'application ainsi que leur authentification.
Création du modèle Entity et de la base de donnée SqlServer
Il manque cruellement une base de données que je vais créer avec Entity Framework :
Création du modèle Entity Framework |
Dans l'éditeur de modèle, je créé trois Entity (trois tables ou trois objets c'est la même chose) de la façon suivante :
Mon Model1.edmx |
Je créé ma base de données SqlServer :
Création de la base SqlServer DataBase1.mdf |
Puis je génère le script de création de la base dans l'éditeur de modèle Entity :
Génération du script de création de la base à partir du modèle |
Jusque là tout va bien.
Installation de MvcScaffolding package Nuget
Je dois utiliser mvcscaffolding pour créer les objets (contrôlers) que je pourrai utiliser dans mon application ASP.NET MVC c'est là que je trouve que les choses sont un peu magiques !
Il faut taper la commande :
PM> install-package mvcscaffolding
dans la console de management des packets qui se trouvent ici :
Afficher la console PM (Package Management) |
Exécution de la commande :
PM> install-package mvcscaffolding
Tentative de résolution de la dépendance « T4Scaffolding ».
Tentative de résolution de la dépendance « T4Scaffolding.Core ».
Tentative de résolution de la dépendance « EntityFramework ».
Installation de « T4Scaffolding.Core 1.0.0 » terminée.
Vous téléchargez EntityFramework à partir de Microsoft. Le contrat de licence est disponible à l’emplacement http://go.microsoft.com/fwlink/?LinkID=320539. Vérifiez si le package contient des dépendances susceptibles de faire l’objet de contrats de licence supplémentaires. Votre utilisation du package et des dépendances confirment votre acceptation de leurs contrats de licence. Si vous n’acceptez pas les contrats de licence, supprimez les composants correspondants de votre ordinateur.
Installation de « EntityFramework 6.1.0 » terminée.
Installation de « T4Scaffolding 1.0.8 » terminée.
Installation de « MvcScaffolding 1.0.9 » terminée.
Ajout réussi de « T4Scaffolding.Core 1.0.0 » à MvcApplication2.
« EntityFramework 5.0.0 » a été supprimé avec succès de MvcApplication2.
Ajout réussi de « EntityFramework 6.1.0 » à MvcApplication2.
Type 'get-help EntityFramework' to see all available Entity Framework commands.
Ajout réussi de « T4Scaffolding 1.0.8 » à MvcApplication2.
Ajout réussi de « MvcScaffolding 1.0.9 » à MvcApplication2.
Désinstallation de « EntityFramework 5.0.0 » terminée.
Utilisation du package MvcScaffolding
Mon package étant installé, je peux maintenant l'utiliser :
J'ai créé trois Entity : Compagny, Region, Departement, je vais donc lancer trois commande :
PM> scaffold controller CompagnyController –force –DBContextType “ModelContainer”
Scaffolding CompagnyController...
Added database context 'Models\ModelContainer.cs'
Added 'Compagny' to database context 'MvcApplication2.Models.ModelContainer'
Get-PrimaryKey : Error HRESULT E_FAIL has been returned from a call to a COM component.
At E:\Templates\MvcApplication2\packages\MvcScaffolding.1.0.9\tools\Controller\MvcScaffolding.Controller.ps1:71 char:29
+ $primaryKey = Get-PrimaryKey <<<< $foundModelType.FullName -Project $Project -ErrorIfNotFound
+ CategoryInfo : NotSpecified: (:) [Get-PrimaryKey], COMException
+ FullyQualifiedErrorId : T4Scaffolding.Cmdlets.GetPrimaryKeyCmdlet
Error du package MvcScaffolding
Et là c'est la drame :
Error du package MvcScaffolding |
Solution du package MvcScaffolding
Comment faire pour se sortir de ce très mauvais pas ! Voici ce que j'ai fais, c'est issu une longue longue expérience des outils et des problèmes Microsoft.
Créer le modèle EDMX au bon endroit
Je recréé le modèle .edmx dans le répertoire modèle afin que les objets générés aient le "bon namespace" car je pense que MvcScaffolding est typiquement le genre d'outil à se planter sinon ...
Le Modèle Entity dans le répertoire Models ... |
Modifier la génération pour obtenir des DbContext
En suite, on voit que Scaffold souhaite des objets de type DbContext c'est plus moderne. Je vais donc bouton-droit dans l'éditeur de modèle Entity pour faire :
Modèle Entity ajout d'une génération spécifique |
Et je choisi :
Choix du EF DbContext Generator |
Dans le fichier :
\\Templates\MvcApplication2\MvcApplication2\Models\Model1.Context.cs
public partial class DataBase1Entities : DbContext
DataDataBase1Entities ne dérive plus de ObjectContext mais de DbContext
Relancer la commande Scaffold
Comme j'ai créé la base à partir du modèle Entity mon objet Compagny s'appelle CompagnySet je lance donc la commande :
PM> scaffold controller CompagnySetController –force –DBContextType “ModelContainer”
Scaffolding CompagnySetController...
Added database context 'Models\ModelContainer.cs'
Added 'CompagnySet' to database context 'MvcApplication2.Models.ModelContainer'
Added controller Controllers\CompagnySetController.cs
Added Create view at 'Views\CompagnySet\Create.cshtml'
Added Edit view at 'Views\CompagnySet\Edit.cshtml'
Added Delete view at 'Views\CompagnySet\Delete.cshtml'
Added Details view at 'Views\CompagnySet\Details.cshtml'
Added Index view at 'Views\CompagnySet\Index.cshtml'
Added _CreateOrEdit view at 'Views\CompagnySet\_CreateOrEdit.cshtml'
Cette fois ça fonctionne et mes objets ont été correctement créés :
CRUD complet sur l'objet Compagny Créé par Entity et Scaffold |
Liste des Compagny |
Et ne trouvez-vous pas cela magique ?