.NET Core - Guide rapide

.NET Core est la dernière plate-forme de développement à usage général maintenue par Microsoft. Il fonctionne sur différentes plates-formes et a été repensé de manière à rendre .NET rapide, flexible et moderne. C'est l'une des contributions majeures de Microsoft. Les développeurs peuvent désormais créer des applications Android, iOS, Linux, Mac et Windows avec .NET, le tout en Open Source.

Dans ce didacticiel, nous aborderons .NET Core et quelques nouvelles innovations, notamment les mises à jour .NET Framework, .NET Standard et Universal Windows Platform, etc.

Caractéristiques de .NET Core

Voici les principales caractéristiques de .NET Core:

Open source

  • .NET Core est une implémentation open source, utilisant les licences MIT et Apache 2.

  • .NET Core est un projet .NET Foundation et est disponible sur GitHub.

  • En tant que projet open source, il favorise un processus de développement plus transparent et promeut une communauté active et engagée.

Multiplateforme

  • L'application implémentée dans .NET Core peut être exécutée et son code peut être réutilisé quelle que soit la cible de votre plateforme.

  • Il prend actuellement en charge trois principaux systèmes d'exploitation (OS)

    • Windows

    • Linux

    • MacOS

  • Les systèmes d'exploitation (OS), processeurs et scénarios d'application pris en charge évolueront au fil du temps, fournis par Microsoft, d'autres sociétés et des particuliers.

Déploiement flexible

  • Il peut y avoir deux types de déploiements pour les applications .NET Core -

    • Déploiement dépendant du framework

    • Déploiement autonome

  • Avec le déploiement dépendant de l'infrastructure, votre application dépend d'une version à l'échelle du système de .NET Core sur laquelle votre application et les dépendances tierces sont installées.

  • Avec le déploiement autonome, la version .NET Core utilisée pour créer votre application est également déployée avec votre application et les dépendances tierces et peut s'exécuter côte à côte avec d'autres versions.

Outils de ligne de commande

  • Tous les scénarios de produit peuvent être exercés sur la ligne de commande.

Compatible

  • .NET Core est compatible avec .NET Framework, Xamarin et Mono, via la bibliothèque standard .NET

Modulaire

  • .NET Core est publié via NuGet dans des packages d'assembly plus petits.

  • .NET Framework est un grand assembly qui contient la plupart des fonctionnalités de base.

  • .NET Core est mis à disposition sous forme de packages plus petits centrés sur les fonctionnalités.

  • Cette approche modulaire permet aux développeurs d'optimiser leur application en incluant uniquement les packages NuGet dont ils ont besoin dans leur application.

  • Les avantages d'une plus petite surface d'application incluent une sécurité plus stricte, un entretien réduit, des performances améliorées et des coûts réduits dans un modèle de paiement à l'utilisation.

La plateforme .NET Core

.NET Core Platform contient les parties principales suivantes -

  • .NET Runtime - Il fournit un système de type, le chargement d'assembly, un garbage collector, une interopérabilité native et d'autres services de base.

  • Fundamental Libraries - Un ensemble de bibliothèques de framework, qui fournissent des types de données primitifs, des types de composition d'application et des utilitaires fondamentaux.

  • SDK & Compiler - Un ensemble d'outils SDK et de compilateurs de langage qui permettent l'expérience développeur de base, disponible dans le SDK .NET Core.

  • ‘dotnet’ app host- Il est utilisé pour lancer les applications .NET Core. Il sélectionne le runtime et héberge le runtime, fournit une politique de chargement d'assembly et lance l'application. Le même hôte est également utilisé pour lancer les outils SDK de la même manière.

Dans ce chapitre, nous aborderons les différentes dépendances dont vous avez besoin pour déployer et exécuter. Celles-ci incluent les applications .NET Core sur les machines Windows développées à l'aide de Visual Studio.

Versions Windows prises en charge

.NET Core est pris en charge sur les versions suivantes de Windows -

  • Windows 7 SP1
  • Windows 8.1
  • Windows 10
  • Windows Server 2008 R2 SP1 (serveur complet ou serveur principal)
  • Windows Server 2012 SP1 (serveur complet ou serveur principal)
  • Windows Server 2012 R2 SP1 (serveur complet ou serveur principal)
  • Windows Server 2016 (Serveur complet, Server Core ou Nano Server)

Dépendances

  • Si vous exécutez votre application .NET Core sur des versions de Windows antérieures à Windows 10 et Windows Server 2016, elle nécessitera également le redistribuable Visual C ++.

  • Cette dépendance est automatiquement installée pour vous si vous utilisez le programme d'installation .NET Core.

  • Vous devez installer manuellement le redistribuable Visual C ++ pour Visual Studio 2015 si vous installez .NET Core via le script du programme d'installation ou déployez une application .NET Core autonome.

  • Pour les machines Windows 7 et Windows Server 2008, vous devez vous assurer que votre installation de Windows est à jour et inclut également le correctif KB2533623 installé via Windows Update.

Prérequis avec Visual Studio

  • Pour développer des applications .NET Core à l'aide du SDK .NET Core, vous pouvez utiliser n'importe quel éditeur de votre choix.

  • Toutefois, si vous souhaitez développer des applications .NET Core sur Windows à l'aide de Visual Studio, vous pouvez utiliser les deux versions suivantes -

    • Visual Studio 2015

    • Visual Studio 2017 RC

  • Les projets créés avec Visual Studio 2015 seront basés sur project.json par défaut, tandis que les projets créés avec Visual Studio 2017 RC seront toujours basés sur MSBuild.

Dans ce chapitre, nous aborderons la configuration de l'environnement de .NET Core. Il s'agit d'une refonte importante du .NET Framework. Pour utiliser .NET Core dans votre application, vous pouvez utiliser deux versions:

  • Visual Studio 2015
  • Visual Studio 2017 RC

Visual Studio 2015

Pour utiliser Visual Studio 2015, vous devez avoir installé les éléments suivants -

  • Mise à jour 3 de Microsoft Visual Studio 2015
  • Microsoft .NET Core 1.0.1 - Aperçu des outils VS 2015 2

Microsoft fournit une version gratuite de Visual Studio qui contient également SQL Server et peut être téléchargée à partir de https://www.visualstudio.com/en-us/downloads/download-visual-studio-vs.aspx et Microsoft .NET Core 1.0.1 - VS 2015 Tooling Preview 2 peuvent être téléchargés à partir de https://www.visualstudio.com/downloads/

Vous pouvez également suivre les instructions d'installation sur l'URL suivante https://www.microsoft.com/net/core/#windowsvs2017

Installation de Visual Studio 2015

Suivez ces étapes pour installer Visual Studio 2015 -

Step 1- Une fois le téléchargement terminé, exécutez le programme d'installation. La boîte de dialogue suivante s'affiche.

Step 2 - Cliquez Install pour démarrer le processus d'installation.

Step 3 - Une fois l'installation terminée, vous verrez la boîte de dialogue suivante.

Step 4 - Fermez cette boîte de dialogue et redémarrez votre ordinateur si nécessaire.

Step 5- Ouvrez Visual Studio à partir du menu Démarrer; vous recevrez la boîte de dialogue suivante. Le chargement et la première utilisation peuvent prendre quelques minutes.

Step 6 - Une fois chargé, vous verrez l'écran suivant.

Step 7 - Une fois l'installation de Visual Studio terminée, fermez Visual Studio et lancez Microsoft .NET Core - VS 2015 Tooling Preview 2.

Step 8 - Cochez la case et cliquez sur Installer.

Step 9 - Une fois l'installation terminée, vous verrez la boîte de dialogue suivante.

Vous êtes maintenant prêt à démarrer votre application à l'aide de .NET Core.

Visual Studio 2017

Dans ce didacticiel, nous utiliserons Visual Studio 2015, mais si vous souhaitez utiliser Visual Studio 2017, une version expérimentale des outils .NET Core pour Visual Studio est incluse dans Visual Studio 2017 RC et vous pouvez voir les instructions d'installation ici https://www.microsoft.com/net/core/#windowsvs2017

Visual Studio 2015 fournit un environnement de développement complet pour le développement d'applications .NET Core. Dans ce chapitre, nous allons créer un nouveau projet dans Visual Studio. Une fois que vous avez installé les outils Visual Studio 2015, vous pouvez commencer à créer une nouvelle application .NET Core.

dans le New Project boîte de dialogue, dans la liste Modèles, développez le nœud Visual C # et sélectionnez .NET Core et vous devriez voir les trois nouveaux modèles de projet suivants

  • Bibliothèque de classes (.NET Core)
  • Application console (.NET Core)
  • Application Web ASP.NET Core (.NET Core)

Dans le volet central de la boîte de dialogue Nouveau projet, sélectionnez Application console (.NET Core) et nommez-la «FirstApp», puis cliquez sur OK.

Visual Studio ouvrira le projet nouvellement créé et vous verrez dans la fenêtre Explorateur de solutions tous les fichiers qui se trouvent dans ce projet.

Pour tester que l'application de la console .NET Core fonctionne, ajoutons la ligne suivante.

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Threading.Tasks; 
  
namespace FirstApp { 
   public class Program { 
      public static void Main(string[] args) { 
         Console.WriteLine("Hello guys, welcome to .NET Core world!"); 
      } 
   } 
}

Maintenant, exécutez l'application. Vous devriez voir la sortie suivante.

.NET Core prend en charge les primitives intégrales numériques standard et à virgule flottante. Il prend également en charge les types suivants -

  • System.Numerics.BigInteger qui est un type intégral sans limite supérieure ou inférieure.

  • System.Numerics.Complex est un type qui représente des nombres complexes.

  • Un ensemble de types de vecteurs compatibles SIMD (Single Instruction Multiple Data) dans l'espace de noms System.Numerics.

Types intégraux

.NET Core prend en charge les entiers signés et non signés de différentes plages allant d'un octet à huit octets de longueur. Tous les entiers sont des types valeur.

Le tableau suivant représente les types intégraux et leur taille;

Type Signé / Non signé Taille (octets) Valeur minimum Valeur maximum
Octet Non signé 1 0 255
Int16 Signé 2 −32 768 32 767
Int32 Signé 4 −2 147 483 648 2 147 483 647
Int64 Signé 8 −9 223 372 036 854 775 808 9 223 372 036 854 775 807
SByte Signé 1 -128 127
UInt16 Non signé 2 0 65 535
UInt32 Non signé 4 0 4 294 967 295
UInt64 Non signé 8 0 18 446 744 073 709 551 615

Chaque type intégral prend en charge un ensemble standard d'opérateurs d'arithmétique, de comparaison, d'égalité, de conversion explicite et de conversion implicite.

Vous pouvez également utiliser les bits individuels dans une valeur entière à l'aide de la classe System.BitConverter.

Types à virgule flottante

.NET Core comprend trois types de virgule flottante primitifs, qui sont indiqués dans le tableau suivant.

Type Taille (octets) Valeur minimum Valeur maximum
Double 8 −1,79769313486232e308 1.79769313486232e308
Célibataire 4 −3,402823e38 3.402823e38
Décimal 16 −79,228,162,514,264,337,593,5 43,950,335 79,228,162,514,264,337,593,543,9 50,335
  • Chaque type à virgule flottante prend en charge un ensemble standard d'opérateurs d'arithmétique, de comparaison, d'égalité, de conversion explicite et de conversion implicite.

  • Vous pouvez également travailler avec les bits individuels dans les valeurs Double et Simple en utilisant la classe BitConverter.

  • La structure Decimal a ses propres méthodes, Decimal.GetBits et Decimal.Decimal (Int32 ()), pour travailler avec les bits individuels d'une valeur décimale, ainsi que son propre ensemble de méthodes pour effectuer des opérations mathématiques supplémentaires.

BigInteger

  • System.Numerics.BigInteger est un type immuable qui représente un entier arbitrairement grand dont la valeur en théorie n'a pas de limites supérieures ou inférieures.

  • Les méthodes du type BigInteger sont étroitement parallèles à celles des autres types intégraux.

Complexe

  • Le type System.Numerics.Complex représente un nombre complexe, c'est-à-dire un nombre avec une partie de nombre réel et une partie de nombre imaginaire

  • Il prend en charge un ensemble standard d'opérateurs d'arithmétique, de comparaison, d'égalité, de conversion explicite et de conversion implicite, ainsi que des méthodes mathématiques, algébriques et trigonométriques.

SIMD

  • L'espace de noms Numerics comprend un ensemble de types de vecteurs compatibles SIMD pour .NET Core.

  • SIMD permet de paralléliser certaines opérations au niveau matériel, ce qui se traduit par d'énormes améliorations de performances dans les applications mathématiques, scientifiques et graphiques qui effectuent des calculs sur des vecteurs.

  • Les types de vecteurs compatibles SIMD dans .NET Core incluent les éléments suivants:

    • Types System.Numerics.Vector2, System.Numerics.Vector3 et System.Numerics.Vector4, qui sont des vecteurs à 2, 3 et 4 dimensions de type Single.

    • La structure Vector <T> qui vous permet de créer un vecteur de n'importe quel type numérique primitif. Les types numériques primitifs incluent tous les types numériques dans l'espace de noms System à l'exception de Decimal.

    • Deux types de matrice, System.Numerics.Matrix3 × 2, qui représente une matrice 3 × 2; et System.Numerics.Matrix4 × 4, qui représente une matrice 4 × 4.

    • Le type System.Numerics.Plane, qui représente un plan en trois dimensions, et le type System.Numerics.Quaternion, qui représente un vecteur utilisé pour coder les rotations physiques en trois dimensions.

Dans ce chapitre, nous aborderons le concept de récupération de place qui est l'une des fonctionnalités les plus importantes de la plate-forme de code managé .NET. Le garbage collector (GC) gère l'allocation et la libération de mémoire. Le garbage collector sert de gestionnaire de mémoire automatique.

  • Vous n'avez pas besoin de savoir comment allouer et libérer de la mémoire ou gérer la durée de vie des objets qui utilisent cette mémoire

  • Une allocation est effectuée chaque fois que vous déclarez un objet avec un mot-clé «nouveau» ou un type de valeur est encadré. Les allocations sont généralement très rapides

  • Lorsqu'il n'y a pas assez de mémoire pour allouer un objet, le GC doit collecter et disposer de la mémoire résiduelle pour rendre la mémoire disponible pour les nouvelles allocations.

  • Ce processus est connu sous le nom de garbage collection.

Avantages de la collecte des ordures

Garbage Collection offre les avantages suivants:

  • Vous n'avez pas besoin de libérer de la mémoire manuellement lors du développement de votre application.

  • Il alloue également efficacement les objets sur le tas géré.

  • Lorsque les objets ne sont plus utilisés, il récupérera ces objets en effaçant leur mémoire et gardera la mémoire disponible pour les allocations futures.

  • Les objets gérés obtiennent automatiquement un contenu propre pour commencer, de sorte que leurs constructeurs n'ont pas à initialiser chaque champ de données.

  • Il assure également la sécurité de la mémoire en s'assurant qu'un objet ne peut pas utiliser le contenu d'un autre objet.

Conditions pour la collecte des ordures

Le garbage collection se produit lorsque l'une des conditions suivantes est remplie.

  • Le système a une mémoire physique faible.

  • La mémoire utilisée par les objets alloués sur le tas géré dépasse un seuil acceptable. Ce seuil est ajusté en continu pendant le déroulement du processus.

  • le GC.Collectméthode est appelée et dans presque tous les cas, vous n'avez pas besoin d'appeler cette méthode, car le garbage collector s'exécute en continu. Cette méthode est principalement utilisée pour des situations et des tests uniques.

Générations

Le garbage collector .NET a 3 générations et chaque génération a son propre tas utilisé pour le stockage des objets alloués. Il existe un principe de base selon lequel la plupart des objets ont une durée de vie courte ou longue.

Première génération (0)

  • Dans la génération 0, les objets sont d'abord alloués.

  • Dans cette génération, les objets ne vivent souvent pas au-delà de la première génération, car ils ne sont plus utilisés (hors de portée) au moment du prochain garbage collection.

  • La génération 0 est rapide à collecter car son tas associé est petit.

Deuxième génération (1)

  • Dans la génération 1, les objets ont un espace de seconde chance.

  • Les objets qui sont de courte durée mais survivent à la collection de génération 0 (souvent basée sur un timing coïncident) vont à la génération 1.

  • Les collectes de génération 1 sont également rapides car le tas associé est également petit.

  • Les deux premiers tas restent petits car les objets sont collectés ou promus vers le tas de génération suivante.

Troisième génération (2)

  • Dans la génération 2, tous les objets longs sont vécus et son tas peut devenir très volumineux.

  • Les objets de cette génération peuvent survivre longtemps et il n'y a pas de tas de nouvelle génération pour promouvoir davantage les objets.

  • Le garbage collector dispose d'un tas supplémentaire pour les objets volumineux connu sous le nom de tas d'objets volumineux (LOH).

  • Il est réservé aux objets de 85 000 octets ou plus.

  • Les grands objets ne sont pas alloués aux tas générationnels mais sont alloués directement à la LOH

  • Les collectes de génération 2 et LOH peuvent prendre un temps notable pour les programmes qui ont été exécutés pendant une longue période ou qui fonctionnent sur de grandes quantités de données.

  • Les grands programmes de serveur sont connus pour avoir des tas de 10 Go.

  • Le GC emploie une variété de techniques pour réduire la durée pendant laquelle il bloque l'exécution du programme.

  • L'approche principale consiste à effectuer autant de travail de ramasse-miettes que possible sur un thread d'arrière-plan d'une manière qui n'interfère pas avec l'exécution du programme.

  • Le GC expose également quelques façons pour les développeurs d'influencer son comportement, ce qui peut être très utile pour améliorer les performances.

Dans ce chapitre, nous allons comprendre le processus d'exécution de .NET Core et le comparer avec le .NET Framework. Le processus d'exécution géré comprend les étapes suivantes.

  • Choisir un compilateur
  • Compiler votre code vers MSIL
  • Compilation de MSIL en code natif
  • Code d'exécution

Choisir un compilateur

  • Il s'agit d'un environnement d'exécution multilingue, le runtime prend en charge une grande variété de types de données et de fonctionnalités de langage.

  • Pour bénéficier des avantages fournis par le Common Language Runtime, vous devez utiliser un ou plusieurs compilateurs de langage qui ciblent le Runtime.

Compiler votre code vers MSIL

  • La compilation traduit votre code source en Microsoft Intermediate Language (MSIL) et génère les métadonnées requises.

  • Les métadonnées décrivent les types de votre code, y compris la définition de chaque type, les signatures des membres de chaque type, les membres auxquels votre code fait référence et d'autres données que le runtime utilise au moment de l'exécution.

  • Le runtime localise et extrait les métadonnées du fichier ainsi que des bibliothèques de classes de framework (FCL) selon les besoins pendant l'exécution.

Compilation de MSIL en code natif

  • Au moment de l'exécution, un compilateur juste à temps (JIT) traduit le MSIL en code natif.

  • Au cours de cette compilation, le code doit passer un processus de vérification qui examine le MSIL et les métadonnées pour savoir si le code peut être déterminé comme étant de type sécurisé.

Code courant

  • Le Common Language Runtime fournit l'infrastructure qui permet à l'exécution d'avoir lieu et les services qui peuvent être utilisés pendant l'exécution.

  • Pendant l'exécution, le code managé reçoit des services tels que le garbage collection, la sécurité, l'interopérabilité avec le code non managé, la prise en charge du débogage multilingue et la prise en charge améliorée du déploiement et du contrôle de version.

Processus d'exécution de code .NET Core

Voyons maintenant comment le code s'exécute avec .NET Core par rapport à .NET Framework. Dans .NET Core, il existe de nombreux remplacements de ces composants qui font partie du .NET Framework.

  • Dans .NET Core, nous avons maintenant une nouvelle série de compilateurs, comme nous avons Roslyn pour C # et VB.

  • Vous pouvez également utiliser le nouveau compilateur F # 4.1 si vous souhaitez utiliser F # avec .NET Core.

  • En fait, ces outils sont différents et nous pouvons également utiliser Roslyn avec .NET Framework si nous utilisons C # 6 ou une version ultérieure, car le compilateur C # ne peut prendre en charge que C # 5.

  • Dans .NET Core, nous n'avons pas de bibliothèques de classes de framework (FCL), donc un ensemble différent de bibliothèques est utilisé et nous avons maintenant CoreFx.

  • CoreFx est la réimplémentation des bibliothèques de classes pour .NET Core.

  • Nous avons également un nouveau temps d'exécution avec .NET Core connu sous le nom de CoreCLR et exploite un compilateur JIT.

  • Maintenant, la question est de savoir pourquoi avons-nous la réimplémentation de tous ces composants que nous avons déjà dans le framework .NET.

  • La réponse est donc la même que la raison pour laquelle Microsoft a implémenté .NET Core.

Créer et implémenter une application modulaire est une autre considération de .NET Core. Au lieu d'installer l'ensemble du .NET Framework, votre application peut maintenant simplement installer ce qui est requis. Passons au studio visuel et voyons la modularité.

Voici notre application .NET Core simple, dans l'Explorateur de solutions. Développons les références et vous verrez une référence à .NETCoreApp

Dans .NETCoreApp, vous verrez une référence de package à NuGet; élargissons-le.

Vous verrez toute la série de références NuGet Package. Si vous avez travaillé dans .NET Framework, la plupart de ces espaces de noms vous sembleront familiers, car vous y êtes habitué à l'aide de .NET Framework.

.NET Framework est divisé en plusieurs parties différentes et réimplémenté avec CoreFx; ces pièces sont ensuite distribuées sous forme d'emballages individuels.

  • Maintenant, si vous développez la NETStandard.Library, vous verrez des références supplémentaires. Vous remarquerez même System.Console que nous utilisons dans cette application.

  • Désormais, vous n'avez pas à tout importer dans .NET Framework, mais simplement à apporter ce dont vous avez besoin pour votre application.

  • Il y a aussi d'autres avantages; par exemple, ces modules peuvent être mis à jour individuellement si vous le souhaitez.

La modularité améliore les performances et votre application peut s'exécuter plus rapidement, en particulier l'application ASP.NET Core.

Dans ce chapitre, nous aborderons les fichiers de projet .NET Core et la manière dont vous pouvez ajouter des fichiers existants dans votre projet.

Comprenons un exemple simple dans lequel nous avons des fichiers déjà créés; nous devons ajouter ces fichiers dans notre projet FirstApp.

Voici la mise en œuvre du Student.cs fichier

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Threading.Tasks; 
  
namespace FirstApp { 
   public class Student { 
      public int ID { get; set; } 
      public string LastName { get; set; } 
      public string FirstMidName { get; set; } 
      public DateTime EnrollmentDate { get; set; } 
   } 
}

Voici la mise en œuvre du Course.cs fichier.

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Threading.Tasks; 
  
namespace FirstApp { 
   public class Course { 
      public int CourseID { get; set; } 
      public string Title { get; set; } 
      public int Credits { get; set; } 
   } 
}

Sauvegardons maintenant ces trois fichiers sur votre disque et le dossier source de votre projet.

  • Maintenant, si vous êtes familiarisé avec .NET et que celui-ci était une application de console .NET Framework traditionnelle, il est important de comprendre comment ajouter ces fichiers dans votre projet dans Visual Studio.

  • Vous devez d'abord faire glisser les fichiers vers l'explorateur de solutions pour les copier dans votre dossier de projet, car votre projet doit faire référence à ces fichiers.

  • L'un des avantages de .NET Core est l'approche adoptée avec le fichier projet (project.json); nous pouvons simplement déposer des fichiers à la racine de notre projet et ceux-ci seront automatiquement inclus dans notre projet.

  • Nous n'avons pas à référencer manuellement les fichiers comme nous l'avons fait dans le passé pour l'application .NET Framework traditionnelle dans Visual Studio.

Ouvrons maintenant la racine de votre projet.

Copions maintenant les trois fichiers à la racine de votre projet.

Vous pouvez maintenant voir tous les fichiers copiés dans le dossier racine.

Passons maintenant à Visual Studio; vous recevrez la boîte de dialogue suivante.

Cliquez sur Yes to All pour recharger votre projet.

Vous allez maintenant que les fichiers sont automatiquement inclus dans votre projet.

Dans ce chapitre, nous verrons comment ajouter des packages dans votre application .NET Core et comment rechercher un package spécifique. Nous pouvons accéder directement à NuGet et ajouter un package, mais ici nous verrons d'autres endroits.

Passons maintenant au code source de .NET Core qui se trouve ici - https://github.com/dotnet/corefx

Dans le référentiel CoreFx, ouvrez le src dossier -

Et vous verrez toute la liste des dossiers qui correspondent aux différents packages. Cherchons maintenant Json -

Il existe une autre façon de trouver votre package, vous connaissez probablement différents types si vous êtes familier avec .NET Framework, mais l'assemblage de packages dans .NET Core est totalement différent et vous ne saurez pas où se trouvent ces packages.

Si vous connaissez le type, vous pouvez rechercher pour inverser la recherche de package en utilisant https://packagesearch.azurewebsites.net/

Ici, vous pouvez saisir tout type de package que vous souhaitez trouver. Ensuite, ce site analysera NuGet et trouvera les packages appropriés pour vous.

Cherchons maintenant DataContractJson.

Vous verrez maintenant que nous obtenons le même package; cliquons sur le paquet.

Vous verrez maintenant la page NuGet; vous devez confirmer que vous avez besoin de ce package. Vous pouvez l'ajouter dans votre application en utilisant quelques méthodes.

Ouvrons le fichier project.json.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "emitEntryPoint": true 
   }, 
   "dependencies": { 
      "Microsoft.NETCore.App": { 
         "type": "platform", 
         "version": "1.0.1" 
      } 
   }, 
   "frameworks": { 
      "netcoreapp1.0": { 
         "imports": "dnxcore50" 
      } 
   } 
}

Il s'agit du nouveau format de projet et dans ce fichier, vous verrez la section des dépendances. Ajoutons une nouvelle dépendance comme indiqué ci-dessous.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "emitEntryPoint": true 
   }, 
   "dependencies": { 
      "Microsoft.NETCore.App": { 
         "type": "platform", 
         "version": "1.0.1" 
      }, 
      "System.Runtime.Serialization.Json": "4.0.2" 
   }, 
   "frameworks": { 
      "netcoreapp1.0": { 
         "imports": "dnxcore50" 
      } 
   } 
}

Maintenant, si vous regardez vos références, vous verrez que System.Runtime.Serialization.Json package est ajouté à votre projet.

Une autre méthode consiste à accéder au gestionnaire NuGet et à parcourir le package que vous souhaitez ajouter.

Dans ce chapitre, nous verrons comment créer une application UWP à l'aide de .NET Core. UWP est également connu sous le nom d'application Windows 10 UWP. Cette application ne fonctionne pas sur les versions précédentes de Windows mais ne fonctionnera que sur la future version de Windows.

Voici quelques exceptions où UWP fonctionnera correctement.

  • Si vous souhaitez l'exécuter localement, vous devez avoir Windows 10, vous pouvez également développer sur Windows 8 et vous devrez ensuite l'exécuter sur Emulator, mais il est encouragé à utiliser Windows 10.

  • Pour l'application UWP, vous aurez également besoin du SDK Windows 10. Ouvrons le programme d'installation de Visual Studio 2015, puis modifions Visual Studio.

  • Sur la page de sélection des fonctionnalités, faites défiler vers le bas et vous verrez Universal Windows App Development Tools, cochez cette option comme indiqué ci-dessous.

Ici, vous pouvez voir les différentes versions du SDK et la dernière mise à jour sur les outils, cliquez sur Suivant.

Maintenant, cliquez sur le Install bouton.

Une fois l'installation terminée, vous devrez redémarrer votre système.

Implémentons maintenant l'UWP en suivant ces étapes.

  • Tout d'abord, lancez Visual Studio 2015.

  • Cliquez sur le menu Fichier et sélectionnez Nouveau → Projet; une boîte de dialogue Nouveau projet apparaîtra. Vous pouvez voir les différents types de modèles dans le volet gauche de la boîte de dialogue.

  • Dans le volet gauche, vous pouvez voir l'arborescence, sélectionnez maintenant Modèle universel dans Modèles → Visual C # → Windows.

  • Dans le volet central, sélectionnez le modèle Blank App (Universal Windows).

  • Donnez un nom au projet en tapant UWPFirstApp dans le champ Nom et cliquez sur OK.

  • La boîte de dialogue version cible / version minimale apparaît. Les paramètres par défaut conviennent pour ce didacticiel, sélectionnez donc OK pour créer le projet.

  • Ici, nous avons un seul projet qui peut cibler tous les appareils Windows 10, et vous remarquerez que .NET Core et UWP simplifient le multi-ciblage.

  • Lorsqu'un nouveau projet s'ouvre, ses fichiers sont affichés sur le côté droit du volet Explorateur de solutions. Vous devrez peut-être choisir l'onglet Explorateur de solutions au lieu de l'onglet Propriétés pour voir vos fichiers.

  • Bien que l'application vierge (fenêtre universelle) soit un modèle minimal, elle contient toujours beaucoup de fichiers. Ces fichiers sont essentiels pour toutes les applications UWP utilisant C #. Chaque projet que vous créez dans Visual Studio contient les fichiers.

  • Pour voir l'exemple en cours, ouvrons MainPage.XAML et ajoutons le code suivant.

<Page 
   x:Class = "UWPFirstApp.MainPage" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:local = "using:UWPFirstApp" 
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008" 
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006" 
   mc:Ignorable = "d">  
   
   <Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}"> 
      <StackPanel HorizontalAlignment = "Center"> 
         <TextBlock Text = "Hello, world!"  
            Margin = "20" 
            Width = "200" 
            HorizontalAlignment = "Left"/> 
         <TextBlock Text = "Write your name." 
            Margin = "20" 
            Width = "200" 
            HorizontalAlignment = "Left"/> 
         <TextBox x:Name = "txtbox"  
            Width = "280" 
            Margin = "20" 
            HorizontalAlignment = "Left"/> 
         <Button x:Name = "button" Content = "Click Me" 
            Margin = "20" 
            Click = "button_Click"/> 
         <TextBlock x:Name = "txtblock"  
            HorizontalAlignment = "Left" 
            Margin = "20"/> 
      </StackPanel> 
   </Grid> 

</Page>

Vous trouverez ci-dessous l'événement de clic du bouton en C #.

using System; 
using System.Collections.Generic; 
using System.IO; 
using System.Linq; 
using System.Runtime.InteropServices.WindowsRuntime; 

using Windows.Foundation; 
using Windows.Foundation.Collections; 

using Windows.UI.Xaml; 
using Windows.UI.Xaml.Controls; 
using Windows.UI.Xaml.Controls.Primitives; 
using Windows.UI.Xaml.Data; 
using Windows.UI.Xaml.Input; 
using Windows.UI.Xaml.Media; 
using Windows.UI.Xaml.Navigation;  

// The Blank Page item template is documented at 
// http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409  

namespace UWPHellowWorld { 
   /// <summary> 
   /// An empty page that can be used on its own or navigated to within a Frame. 
   /// </summary> 
   public sealed partial class MainPage : Page { 
      public MainPage() { 
         this.InitializeComponent(); 
      }  
      private void button_Click(object sender, RoutedEventArgs e) { 
         if (txtbox.Text != "") 
            txtblock.Text = "Hello: " + txtbox.Text; 
         else 
            txtblock.Text = "You have not write your name"; 
      } 
   } 
}

Exécutons maintenant le code ci-dessus sur la machine locale et vous verrez la fenêtre suivante. Tapez maintenant n'importe quel nom dans la zone de texte et appuyez sur la toucheClick Me bouton.

Dans ce chapitre, nous discuterons de ce qu'est MSBuild et de son fonctionnement avec .NET Core. MSBuild est la plate-forme de construction pour Microsoft et Visual Studio. Dans l'application UWP, si vous ouvrez le dossier du projet, vous verrez à la fois les fichiers project.json et * .csproj.

Mais si vous ouvrez notre précédente application .NET Core Console, vous verrez les fichiers project.json et * .xproj.

  • Le système de génération .NET Core ou le système de génération project.json ne sont pas suffisants pour les besoins UWP; c'est pourquoi UWP utilise toujours le système Build * .csproj (MSBuild).

  • Mais project.json déménagera en ce qui concerne le système de construction.

  • Maintenant, si vous souhaitez ajouter quelques fichiers existants à votre application UWP comme nous l'avons ajouté dans l'application Console, vous devez ajouter ces fichiers dans le dossier du projet. En outre, vous devrez également inclure dans votre projet dans l'Explorateur de solutions.

Considérons maintenant les fichiers suivants; copiez ces fichiers dans votre dossier de projet.

Revenons à Visual Studio et ouvrons l'Explorateur de solutions.

  • Vous pouvez maintenant voir que seule la copie de fichiers n'est pas suffisante dans le cas d'applications UWP, car dans l'Explorateur de solutions, nous ne pouvons pas voir ces fichiers.

  • Maintenant, nous devons également inclure ces fichiers en cliquant sur le bouton Show All Files icône comme mis en évidence dans la capture d'écran ci-dessus et vous verrez maintenant tous les fichiers dans le dossier du projet.

Ces deux fichiers ne sont toujours pas inclus dans notre projet. Pour inclure ces fichiers, sélectionnez ces fichiers et cliquez avec le bouton droit sur n'importe quel fichier, puis sélectionnezInclude in Project.

Maintenant, ces fichiers sont également inclus. Une bonne chose à prévoir est l'approche project.json consistant à déposer des fichiers pour * .csproj dans la future version des outils SKD et également dans Visual Studio.

Dans ce chapitre, nous discuterons des références entre notre application Console et notre application UWP. Si vous regardez les références dans l'Explorateur de solutions de votre application console, vous verrez le .NETCoreApp comme indiqué ci-dessous.

.NETCoreApp est un nouveau framework qui ciblait l'application .NET Core. Maintenant, si vous regardez sous les références de l'application UWP, cela sera un peu différent, comme indiqué ci-dessous.

  • La raison principale en est que nous avons ici dans UWP le * .csproj, nous sommes donc revenus à l'ancien style de références et nous ne pouvons cibler qu'un seul framework avec ce type de projet.

  • Les références sont cependant similaires. Vous pouvez maintenant voir que dans l'application UWP, la référence du package NuGet Miscrosoft.NETCore.UniversalWindowsPlatform est similaire à la référence NuGet Microsoft.NETCore.App dans l'application Console.

  • Miscrosoft.NETCore.UniversalWindowsPlatform et Microsoft.NETCore.App sont tous deux des méta-packages, ce qui signifie qu'ils sont composés d'autres packages.

  • Dans l'application Console, nous pouvons explorer et voir d'autres packages dans Microsoft.NETCore.App, mais nous ne pouvons pas faire la même chose Miscrosoft.NETCore.UniversalWindowsPlatform dans l'Explorateur de solutions.

  • Cependant, nous pouvons utiliser un autre outil, l'Explorateur de packages NuGet pour examiner cela. Ouvrons maintenant cette URL dans le navigateur -https://npe.codeplex.com/downloads/get/clickOnce/NuGetPackageExplorer.application et vous verrez un petit utilitaire de téléchargement.

  • Une fois le téléchargement terminé, double-cliquez sur ce fichier.

  • Cliquez sur Install pour démarrer l'installation sur l'Explorateur de packages NuGet.

  • Lorsque l'installation est terminée, vous verrez la boîte de dialogue suivante.

  • Cliquons maintenant sur le Open a package from online feed option.

  • Par défaut, il recherchera le flux nuget.org. Recherchez maintenant Microsoft.NETCore.UniversalWindowsPlatform dans la zone de recherche et vous verrez 1 résultat comme indiqué ci-dessous.

  • Clique le open link et il ouvrira les dépendances de niveau supérieur de ce métapaquet.

  • Ouvrons maintenant le méta-package .NETCore pour l'application .NETCore et le méta-package pour l'application UWP côte à côte.

  • Vous pouvez maintenant voir que chaque méta-package est composé de différents ensembles de packages.

  • .NET Core est un sous-ensemble des classes disponibles dans .NET Framework au moins à ce stade du temps, mais est en croissance et sera conforme aux classes de base de .NET Framework.

  • L'UWP est basé sur .NET Core, c'est un sur-ensemble des API disponibles pour le développement du Windows Store.

Nous avons maintenant plus d'API disponibles pour le développement grâce à .NET Core.

Les composants Windows Runtime sont des objets autonomes que vous pouvez instancier et utiliser à partir de n'importe quel langage, y compris C #, Visual Basic, JavaScript et C ++. En plus du méta-package .NET Core que nous avons vu dans le chapitre précédent, l'application UWP a également une référence par défaut à un SDK Windows universel.

Universal Windows est la référence à Windows Runtime et il a été pris en compte dans une série de contrats d'API.

L'ensemble des API au sein d'une famille d'appareils est divisé en subdivisions appelées contrats d'API. Vous pouvez trouver une liste des différents contrats d'API icihttps://msdn.microsoft.com/en-us/library/windows/apps/dn706135.aspx

La plupart de ces API à l'intérieur du runtime Windows sont prises en compte dans un seul contrat. Cherchons maintenant le mot-clé Universel sur la page Contrats API.

Vous pouvez voir des liens vers diverses API et vous pouvez également voir que la famille Universal est si grande qu'elle contient 12 pages de documentation.

Vous pouvez également rechercher un contrat d'API de téléphone sur cette page.

Cliquons maintenant sur le Windows.Phone.PhoneContractet faites défiler vers le bas; vous verrez maintenant les informations de batterie du téléphone ou de l'appareil mobile.

Si vous souhaitez ajouter ces informations en plus de ce que vous avez déjà, vous devez ajouter les références manuellement. Passons maintenant à Visual Studio et cliquez avec le bouton droit sur les références dans l'Explorateur de solutions.

Sélectionner Add References…

Vous pouvez maintenant voir la nouvelle catégorie de référence pour Universal Windows; dans cette catégorie, il y a Core qui fait référence aux contrats de base de l'API Windows universelle

  • Les extensions nous permettent d'étendre la fonctionnalité et vous verrez différentes références Mobile, Desktop et autres extensions.

  • Il existe différentes extensions SKD et vous pouvez en ajouter pour obtenir plus d'API.

  • Vous pouvez également voir différentes versions. Assurez-vous donc d'obtenir la dernière version pour obtenir les API mises à jour, puis cliquez sur OK.

Tu peux maintenant voir ça Windows Mobile Extensions for the UWP est ajouté comme référence.

Une bibliothèque de classes définit les types et méthodes qui peuvent être appelés à partir de n'importe quelle application.

  • Une bibliothèque de classes développée à l'aide de .NET Core prend en charge la bibliothèque standard .NET, qui permet à votre bibliothèque d'être appelée par toute plate-forme .NET prenant en charge cette version de la bibliothèque standard .NET.

  • Lorsque vous avez terminé votre bibliothèque de cours, vous pouvez décider si vous souhaitez la distribuer en tant que composant tiers ou si vous souhaitez l’inclure en tant que composant fourni avec une ou plusieurs applications.

Commençons par ajouter un projet de bibliothèque de classes dans notre application Console; faites un clic droit sur lesrc dossier dans l'Explorateur de solutions et sélectionnez Add → New Project…

dans le Add New Project boîte de dialogue, choisissez le nœud .NET Core, puis choisissez le modèle de projet Bibliothèque de classes (.NET Core).

Dans la zone de texte Nom, saisissez "UtilityLibrary" comme nom du projet, comme le montre la figure suivante.

Cliquez sur OK pour créer le projet de bibliothèque de classes. Une fois le projet créé, ajoutons une nouvelle classe. Faites un clic droit surproject dans l'Explorateur de solutions et sélectionnez Add → Class...

Sélectionnez la classe dans le volet central et entrez StringLib.cs dans le nom et le champ, puis cliquez sur Add. Une fois la classe ajoutée, remplacez le code suivant dans le fichier StringLib.cs.

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Threading.Tasks; 
  
namespace UtilityLibrary { 
   public static class StringLib { 
      public static bool StartsWithUpper(this String str) { 
         if (String.IsNullOrWhiteSpace(str)) 
         return false; 
         Char ch = str[0]; 
         return Char.IsUpper(ch); 
      } 
      public static bool StartsWithLower(this String str) { 
         if (String.IsNullOrWhiteSpace(str)) 
         return false; 
         Char ch = str[0]; 
         return Char.IsLower(ch); 
      } 
      public static bool StartsWithNumber(this String str) { 
         if (String.IsNullOrWhiteSpace(str)) 
         return false;  
         Char ch = str[0]; 
         return Char.IsNumber(ch); 
      } 
   } 
}
  • La bibliothèque de classe, UtilityLibrary.StringLib, contient des méthodes comme, StartsWithUpper, StartsWithLower, et StartsWithNumber qui renvoie une valeur booléenne indiquant si l'instance de chaîne actuelle commence respectivement par une majuscule, une minuscule et un nombre.

  • Dans .NET Core, le Char.IsUpper renvoie true si un caractère est en majuscules, la méthode Char.IsLower renvoie true si un caractère est en minuscules, et de la même manière, la méthode Char.IsNumber renvoie true si un caractère est un numérique.

  • Dans la barre de menus, choisissez Build, Build Solution. Le projet doit se compiler sans erreur.

  • Notre projet de console .NET Core n'a pas accès à notre bibliothèque de classes.

  • Maintenant, pour consommer cette bibliothèque de classes, nous devons ajouter une référence à cette bibliothèque de classes dans notre projet de console.

Pour ce faire, développez FirstApp et cliquez avec le bouton droit sur Références et sélectionnez Add Reference…

Dans la boîte de dialogue Gestionnaire de références, sélectionnez UtilityLibrary, notre projet de bibliothèque de classes, puis cliquez sur OK.

Ouvrons maintenant le fichier Program.cs du projet de console et remplaçons tout le code par le code suivant.

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Threading.Tasks; 
using UtilityLibrary; 

namespace FirstApp { 
   public class Program { 
      public static void Main(string[] args) { 
         int rows = Console.WindowHeight; 
         Console.Clear(); 
         do { 
            if (Console.CursorTop >= rows || Console.CursorTop == 0) { 
               Console.Clear(); 
               Console.WriteLine("\nPress <Enter> only to exit; otherwise, enter a string and press <Enter>:\n"); 
            } 
            string input = Console.ReadLine(); 
            
            if (String.IsNullOrEmpty(input)) break; 
            Console.WriteLine("Input: {0} {1,30}: {2}\n", input, "Begins with uppercase? ", 
            input.StartsWithUpper() ? "Yes" : "No"); 
         } while (true); 
      } 
   } 
}

Laissez-nous maintenant exécuter votre application et vous verrez la sortie suivante.

Pour une meilleure compréhension, utilisons les autres méthodes d'extension de votre bibliothèque de classes dans votre projet.

Dans ce chapitre, nous discuterons de ce qu'est PCL (Portable Class Library), et aussi pourquoi nous avons besoin de PCL. Pour comprendre ce concept, ouvrons le dossier de projet de bibliothèque de classes que nous avons créé dans le chapitre précédent.

Dans ce dossier, vous pouvez voir qu'en plus des fichiers project.json et CS, nous avons également un fichier * .xproj, et c'est parce que Visual Studio configure le type de projet .NET Core comme * .xproj au lieu de * .csproj.

Comme mentionné par Microsoft, * .xproj disparaîtra, mais il est toujours présent dans l'outillage de l'aperçu 2. Comme nous l'avons vu, cette application UWP utilise le * .csproj.

Maintenant, il n'est en fait pas possible d'obtenir * .csproj comme référence et * .xproj et cette fonctionnalité ne sera pas implémentée parce que * .xproj sera déplacé.

Nous avons donc besoin d'une bibliothèque de classes qui peut être partagée entre l'application console et l'application UWP et voici PCL.

Qu'est-ce que PCL

Comprenons maintenant ce qu'est PCL -

  • Le projet Bibliothèque de classes portable vous permet d'écrire et de créer des assemblys gérés qui fonctionnent sur plusieurs plates-formes .NET Framework.

  • Vous pouvez créer des classes qui contiennent du code que vous souhaitez partager dans de nombreux projets, comme la logique métier partagée, puis référencer ces classes à partir de différents types de projets.

  • Il peut également vous aider à créer rapidement et facilement des applications et des bibliothèques multiplateformes pour les plates-formes Microsoft.

  • Les bibliothèques de classes portables peuvent vous aider à réduire le temps et les coûts de développement et de test du code.

  • Utilisez ce type de projet pour écrire et créer des assemblys .NET Framework portables, puis référencer ces assemblys à partir d'applications qui ciblent plusieurs plates-formes telles que Windows et Windows Phone, etc.

Supprimons maintenant la bibliothèque de classes que nous avons créée à partir de l'Explorateur de solutions. En même temps, supprimez-le du dossier Solution et ajoutez un nouvel élément de projet.

Sélectionnez le Visual C# → Windows modèle dans le volet gauche et sélectionnez Bibliothèque de classes (portable) dans le volet central.

Entrez StringLibrary dans le champ de nom et cliquez sur OK pour créer ce projet.

Nous devons maintenant sélectionner les frameworks cibles à référencer. Choisissons un instant Windows Universal et ASP.NET Core puis nous le reciblerons. Cliquez surOK.

Vous pouvez voir qu'il a créé un nouveau projet au format PCF. Faisons maintenant un clic droit sur le projet StringLibrary dans l'Explorateur de solutions et sélectionnez Propriétés.

Cliquez sur Target .NET Platform Standard.

Cliquez sur Oui; c'est maintenant la même bibliothèque de classes avec une petite différence. La différence est qu'il peut également être utilisé par UWP, car il contient un fichier * .csproj au lieu de * .xproj.

Ajoutons maintenant une nouvelle classe; pour cela, vous devez faire un clic droit sur le projet dans l'Explorateur de solutions et sélectionnerAdd → Class...

Sélectionnez la classe dans le volet central et entrez StringLib.cs dans le champ de nom, puis cliquez sur Add. Une fois la classe ajoutée, remplacez le code suivant dans le fichier StringLib.cs.

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Threading.Tasks; 
  
namespace StringLibrary { 
   public static class StringLib { 
      public static bool StartsWithUpper(this String str) { 
         if (String.IsNullOrWhiteSpace(str)) 
            return false; 
         Char ch = str[0]; 
         return Char.IsUpper(ch); 
      } 
      public static bool StartsWithLower(this String str) { 
         if (String.IsNullOrWhiteSpace(str)) 
            return false; 
         Char ch = str[0]; 
         return Char.IsLower(ch); 
      } 
      public static bool StartsWithNumber(this String str) { 
         if (String.IsNullOrWhiteSpace(str)) 
            return false; 
         Char ch = str[0]; 
         return Char.IsNumber(ch); 
      } 
   } 
}

Construisons ce projet de bibliothèque de classes portable et il devrait se compiler sans erreur. Nous devons maintenant ajouter une référence à cette bibliothèque de classes portable dans notre projet de console. Alors, développez FirstApp et cliquez avec le bouton droit sur Références et sélectionnezAdd Reference…

Dans la boîte de dialogue Gestionnaire de références, sélectionnez StringLibrary qui est notre projet de bibliothèque de classes portable, puis cliquez sur OK.

Vous pouvez voir que la référence StringLibrary est ajoutée au projet de console et qu'elle peut également être vue dans le fichier project.json.

Vous pouvez maintenant exécuter à nouveau l'application et vous verrez la même sortie.

Utilisons maintenant les autres méthodes d'extension de votre bibliothèque de classes portable dans votre projet. La même bibliothèque portable sera également utilisée dans votre application UWP.

Dans ce chapitre, nous verrons comment ajouter des références à votre bibliothèque. Ajouter des références à une bibliothèque revient à ajouter des références à vos autres projets, comme le projet console et le projet UWP.

Vous pouvez maintenant voir que le projet PCL a des références par défaut. Vous pouvez également ajouter d'autres références selon les besoins de votre application.

Dans la bibliothèque PCL, vous pouvez également voir le fichier project.json.

{ 
   "supports": {}, 
   "dependencies": { 
      "NETStandard.Library": "1.6.0", 
      "Microsoft.NETCore.Portable.Compatibility": "1.0.1" 
   }, 
   "frameworks": { 
      "netstandard1.3": {} 
   } 
}

Une méthode pour ajouter des références à votre bibliothèque consiste à la saisir directement dans le fichier project.json. Comme vous pouvez le voir, nous avons ajouté quelques références sous la section des dépendances, comme indiqué dans le code suivant.

{ 
   "supports": {}, 
   "dependencies": { 
      "NETStandard.Library": "1.6.0", 
      "Microsoft.NETCore.Portable.Compatibility": "1.0.1", 
      "System.Runtime.Serialization.Json": "4.0.3", 
      "Microsoft.EntityFrameworkCore": "1.1.0" 
   }, 
   "frameworks": { 
      "netstandard1.3": {} 
   } 
}

Sauvegardons maintenant ce fichier et vous verrez que des références sont maintenant ajoutées à votre bibliothèque.

L'autre méthode d'ajout de références à votre bibliothèque est le gestionnaire de package NuGet. Faisons maintenant un clic droit sur leStringLibrary (Portable) projet et sélectionnez Mange NuGet Packages…

Sous l'onglet Parcourir, vous pouvez rechercher n'importe quel package NuGet; disons que nous voulons ajouter le package «System.Runtime.Serialization.Primitives».

Clique le Install bouton, qui affichera l'écran suivant.

Maintenant, cliquez sur le OK bouton.

Enfin, cliquez sur le I Acceptbouton pour démarrer l'installation de ce package NuGet. Une fois l'installation terminée, vous verrez que le package NuGet «System.Runtime.Serialization.Primitives» est ajouté à votre bibliothèque.

Dans ce chapitre, nous verrons comment partager votre bibliothèque en NuGet Packageafin qu'il puisse être consommé dans un autre projet. La création d'un package commence par le code que vous souhaitez empaqueter et partager avec d'autres, soit via la galerie publique nuget.org ou une galerie privée au sein de votre organisation. Le package peut également inclure des fichiers supplémentaires tels qu'unreadme qui s'affiche lorsque le package est installé et peut inclure des transformations vers certains fichiers de projet.

Considérons maintenant un exemple simple dans lequel nous allons créer un package NuGet à partir de notre bibliothèque. Pour ce faire, ouvrez l'invite de commande et accédez au dossier où se trouve le fichier project.json de votre projet de bibliothèque.

Exécutons maintenant la commande suivante.

dotnet help

À la fin, vous pouvez voir différentes commandes comme new, restaurer et compiler, etc.

La dernière commande est pack;cela créera un package NuGet. Exécutons maintenant la commande suivante.

dotnet pack

Vous pouvez maintenant voir que les packages NuGet sont produits dans le dossier bin; ouvrons le dossier bin \ Debug.

Maintenant, la question est de savoir ce qu'il y a à l'intérieur des packages NuGet, pour voir que nous pouvons utiliser NuGet Package Explorer. Ouvrons maintenant l'explorateur de packages NuGet.

Sélectionnez la première option Open a local package.

Sélectionnez le StringLibrary.1.0.0.nupkg et cliquez Open.

Vous pouvez voir que dans la section Contenu du package, nous n'avons que StringLibrary.dll. Dans la section Métadonnées du package, vous verrez un peu d'informations sur cette bibliothèque comme l'ID, les versions et toutes les dépendances.

Ouvrons maintenant le StringLibrary.1.0.0.symbols.nupkg.

Dans ce package NuGet, vous verrez les fichiers source et le *.pdbfichier ainsi. Si vous double-cliquez sur leStringLib.cs fichier, vous voyez également le code source.

Ici, la question est de savoir comment configurer les métadonnées telles que la version, les auteurs et la description, etc.

Le fichier project.json est utilisé sur les projets .NET Core pour définir les métadonnées du projet, les informations de compilation et les dépendances. Ouvrons maintenant le fichier project.json et ajoutons les informations supplémentaires suivantes.

{ 
   "authors": [ "Mark Junior" ], 
   "description": "String Library API", 
   "version" : "1.0.1-*", 
   "supports": {}, 
   
   "dependencies": { 
      "Microsoft.EntityFrameworkCore": "1.1.0", 
      "Microsoft.NETCore.Portable.Compatibility": "1.0.1", 
      "NETStandard.Library": "1.6.0", 
      "System.Runtime.Serialization.Json": "4.0.3", 
      "System.Runtime.Serialization.Primitives": "4.3.0" 
   }, 
   "frameworks": { 
      "netstandard1.3": {} 
   } 
}

Vous pouvez maintenant voir des informations supplémentaires telles que le nom de l'auteur, la description et la version ajoutées ici. Sauvegardons ce fichier, construisons le projet de bibliothèque, puis exécutons à nouveau la commande «dotnet pack».

Dans le dossier bin \ Debug, vous pouvez voir que les packages NuGet StringLibrary sont produits avec la version 1.0.1; ouvrons-le dans NuGet Package Explorer.

Vous verrez les métadonnées mises à jour. La question est maintenant de savoir comment l'utiliser dans un autre package.

Nous devons commencer par publier quelque part dans le flux NuGet, puis nous pouvons le consommer dans un autre projet.

Il existe deux options pour publier les métadonnées mises à jour -

  • Publiez-le sur nuget.org
  • Transférer les métadonnées vers un flux NuGet privé

Ici, nous utiliserons le flux NuGet privé car c'est beaucoup plus facile que de configurer un compte sur nuget.org. Pour savoir comment publier votre package sur nuget.org, vous pouvez suivre toutes les instructions spécifiées icihttps://docs.microsoft.com/en-us/nuget/create-packages/publish-a-package.

Suivez ces étapes pour transmettre les métadonnées mises à jour au flux NuGet privé.

Step 1- Pour commencer, nous avons besoin de l'utilitaire de ligne de commande nuget et nous devons l'installer. Ouvrons maintenant le gestionnaire de packages NuGet et recherchons nuget.commandline.

Step 2 - Sélectionnez Nuget.Commandline et cliquez sur Install.

Step 3 - Cliquez OKpour installer Nuget.Commandline. Vous pouvez également l'installer manuellement en le téléchargeant à partir de l'URL suivantehttps://dist.nuget.org/index.html puis configurez la variable d'environnement.

Step 4 - Une fois l'installation terminée, ouvrons à nouveau l'invite de commande et allons dans le bin\Debug dossier où se trouvent les packages NuGet et spécifiez la commande suivante -

nuget add StringLibrary.1.0.1.nupkg -Source D:\PrivateNugetPackages

Step 5 - Dans la commande ci-dessus, nous ajoutons le package StringLibrary.1.0.1.nupkg à notre flux privé et l'emplacement est D:\PrivateNugetPackages, -Source spécifie la source du package.

Step 6 - Vous pouvez voir que le StringLibraryest installé; laStringLibrary peut en outre être ajouté au flux privé.

Step 7 - Allons dans ce dossier.

Step 8 - À l'intérieur du stringlibrary dossier, vous verrez un autre dossier avec le nom de la version et ici c'est 1.0.1.

Le package NuGet se trouve ici.

Dans ce chapitre, nous verrons comment consommer le package NuGet que nous avons créé et publié dans un flux NuGet privé. Nous allons donc d'abord créer un projet Xamarin.Forms. Nous devons d'abord comprendre ce qu'est Xamarin.Forms.

  • Xamarin.Forms est une infrastructure qui permet aux développeurs de créer rapidement des interfaces utilisateur multiplateformes.

  • Xamarin.Forms est une abstraction de boîte à outils d'interface utilisateur multiplateforme sauvegardée en mode natif qui permet aux développeurs de créer facilement des interfaces utilisateur pouvant être partagées sur Android, iOS, Windows et Windows Phone.

  • Les interfaces utilisateur sont rendues à l'aide des contrôles natifs de la plate-forme cible, ce qui permet aux applications Xamarin.Forms de conserver l'apparence appropriée pour chaque plate-forme.

Pour démarrer Xamarin.Forms, nous avons besoin de certaines fonctionnalités supplémentaires dans Visual Studio 2015. Laissez-nous modifier votre Visual Studio 2015 et assurez-vous que l'option de développement mobile multiplateforme suivante est sélectionnée.

Une fois l'installation terminée, mettons à jour le Xamarin en sélectionnant Tools → Options…

Faites défiler vers le bas et développez Xamarin dans le volet gauche, puis sélectionnez Other. Dans le coin supérieur droit de la boîte de dialogue, cliquez surCheck Now pour voir si des mises à jour sont disponibles.

Vous pouvez voir que des mises à jour sont disponibles, cliquons sur le Downloadbouton pour démarrer le téléchargement. Une fois le téléchargement terminé, vous serez invité à installer les mises à jour.

Ouvrons à nouveau le Visual Studio et sélectionnons le File → New → Project… option de menu.

Dans le volet gauche, sélectionnez le Visual C# → Cross-Platform modèle et dans le volet central, sélectionnez Blank Xaml App (Xamarin.Forms Portable). Entrez le nom dans le champ Nom et cliquez sur OK.

Sélectionnez la version cible et la version minimale et cliquez sur OK.

Vous verrez une série de projets; en haut, nous avons la bibliothèque PCL qui sera partagée entre toutes les plates-formes comme Android, iOS, UWP, Windows 8.1 et Windows Phone 8.1.

Ici, nous nous concentrerons sur la bibliothèque PCL et apporterons du code ici. Développons le code.

Dans ce modèle Xamarin.Forms, vous pouvez voir le App.xaml générique et MainPage.xaml, utilise le framework XAML Xamarin.Forms qui fonctionne sur ces plates-formes.

Nous devons importer nos codes et nous avons également besoin du flux NuGet privé que nous avons configuré dans le dernier chapitre.

Ouvrons maintenant le gestionnaire de packages NuGet. Cliquez sur la roue à côté de la liste déroulante Source du package.

Nous devons ajouter notre flux privé ici, cliquons sur le plus (+) button.

Vous verrez qu'une autre case à cocher est ajoutée dans le Available package sources section, laissez-nous spécifier un nom et un chemin source et cliquez sur OK.

Passons maintenant à l'onglet Parcourir et sélectionnez PrivateSource dans la liste déroulante Source du package et vous verrez le package NuGet StringLibrary. Sélectionnez StringLibrary et cliquez surInstall.

Cliquez sur OK et vous verrez une erreur.

Nous ne pouvons pas utiliser la bibliothèque avec le profil .NETPortable version 259, nous corrigerons cette erreur dans le chapitre suivant.

Dans ce chapitre, nous corrigerons l'erreur que nous avons obtenue lors de l'installation du package NuGet à partir de notre flux privé dans le projet Xamarin.Forms.

Nous comprendrons davantage le problème en bref. Pour commencer, faites un clic droit sur la bibliothèque PCL et sélectionnez Propriétés.

Sur cette page, vous verrez toute la série de frameworks ciblés. À partir de l'erreur, vous pouvez voir que le profil .NETPortable 259 n'est pas compatible avec notre StringLibrary 1.0.1. Cependant, il tente de prendre référence à la bibliothèque .NET Standard 1.1.

Voyons maintenant la bibliothèque standard .NET et identifions quelle plate-forme n'est pas compatible avec notre bibliothèque.

Vous pouvez voir que Windows Phone Silverlight 8 est compatible avec .NET Standard 1.0. Si vous ouvrez la page Web suivante, vous verrez que Profile259 ne peut prendre en charge que .NET Standard 1.0.

Désactivons maintenant Windows Phone Silverlight 8.

Clique le OK bouton.

Maintenant, pour résoudre ce problème, cliquez sur OK et annulez la boîte de dialogue Modifier les cibles, puis ouvrez la console du gestionnaire de package et exécutez la commande suivante.

PM > Uninstall-Package Xamarin.Forms

Passons maintenant aux propriétés de la bibliothèque PCL. Cliquez sur le bouton Modifier.

Décochez Windows Phone Silverlight 8 et cliquez sur OK.

Vous pouvez maintenant voir que Windows Phone Silverlight 8 n'est plus disponible dans le cadre ciblé. Vous pouvez également voir le profil qui est la cible maintenant. Pour voir cela, déchargons la bibliothèque PCL et modifions le fichier XamarinApp.csproj.

Vous pouvez maintenant voir que TargetFrameworkProfile est maintenant Profile111.

Si vous ouvrez la documentation, vous verrez que Profile111 prend en charge .NET Standard 1.1.

Rechargeons maintenant le PCL, ouvrons le gestionnaire de packages NuGet et essayons d'installer le package StringLibrary à partir d'un flux privé.

Dans la liste déroulante Comportement des dépendances, sélectionnez Ignorer les dépendances, puis cliquez sur Install.

Vous pouvez voir que le package StringLibrary est maintenant installé à partir du flux privé. Si vous développez les références de PCL, vous verrez que la référence StringLibrary est également ajoutée comme indiqué ci-dessous.

Nous avions désinstallé Xamarin.Forms pour le problème Windows Phone Silverlight 8. Le Xamarin.Forms doit être installé à nouveau. Il est recommandé d'installer la même version.

Une fois l'installation terminée, utilisons la fonctionnalité StringLibrary dans votre application.

Dans ce chapitre, nous verrons comment créer un projet de test à l'aide de .NET Core. Les tests unitaires sont un processus de développement pour le logiciel contenant les plus petites parties testables d'une application, appelées unités. Ils sont examinés individuellement et indépendamment pour tout fonctionnement correct. Les tests unitaires peuvent être automatisés ou également effectués manuellement.

Ouvrons maintenant la boîte de dialogue Nouveau projet et sélectionnez Visual C# → .NET Core modèle.

Dans cette boîte de dialogue, vous pouvez voir qu'il n'y a pas de modèle de projet pour les tests unitaires. Pour créer un projet de test unitaire, nous devons utiliser l'utilitaire de ligne de commande. Allons dans le dossier Solution que nous avons créé; créer un dossier de test et à l'intérieur du dossier de test créer un autre dossier et l'appelerStringLibraryTests.

Utilisons maintenant l'utilitaire de ligne de commande dotnet pour créer un nouveau projet de test en exécutant la commande suivante -

dotnet new -t xunittest

Vous pouvez maintenant voir qu'un nouveau projet C # est créé; examinons le dossier en exécutant lev commande et vous verrez project.json et Tests.cs fichiers comme indiqué ci-dessous.

Voici le code dans le fichier project.json.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "debugType": "portable" 
   }, 
   "dependencies": { 
      "System.Runtime.Serialization.Primitives": "4.1.1", 
      "xunit": "2.1.0", 
      "dotnet-test-xunit": "1.0.0-rc2-192208-24" 
   }, 
   "testRunner": "xunit", 
   "frameworks": { 
      "netcoreapp1.0": { 
         "dependencies": { 
            "Microsoft.NETCore.App": { 
               "type": "platform", 
               "version": "1.0.1" 
            } 
         }, 
         "imports": [ 
            "dotnet5.4", 
            "portable-net451+win8" 
         ] 
      } 
   } 
}

Voici le code dans le fichier Test.cs.

using System; 
using Xunit; 
namespace Tests { 
   public class Tests { 
      [Fact] 
      public void Test1() { 
         Assert.True(true); 
      } 
   } 
}

Pour récupérer les dépendances nécessaires à partir de NuGet, exécutons la commande suivante -

dotnet restore

Nous pouvons exécuter le test lorsque les dépendances nécessaires sont restaurées.

Vous pouvez voir que la compilation a réussi; en descendant, vous pouvez voir des informations sur le test exécuté.

Actuellement, nous avons 1 test exécuté, 0 erreur, 0 échec, 0 ignoré et le temps nécessaire au processus d'exécution est également mentionné comme information.

Dans ce chapitre, nous verrons comment exécuter des tests dans Visual Studio. Le .NET Core a été conçu avec la testabilité à l'esprit, de sorte que la création de tests unitaires pour vos applications est plus facile que jamais. Dans ce chapitre, nous allons exécuter et exécuter notre projet de test dans Visual Studio.

Ouvrons la solution FirstApp dans Visual Studio.

Vous pouvez voir qu'il ne comporte que deux projets et vous ne pourrez pas voir le projet de test car nous n'avons pas ajouté ce projet dans notre solution.

Ajoutons d'abord un dossier et appelons-le test.

Faites un clic droit sur le test dossier.

Sélectionner project.json fichier et cliquez Open.

La capture d'écran suivante montre le code dans Tests.cs fichier en sortie.

Il s'agit de l'implémentation par défaut et il s'agit simplement de tester que True est égal à true. Il s'agit du cadre de test xUnit et vous verrez l'attribut Fact qui annote et désigne la méthode de test.

using System; 
using Xunit; 
  
namespace Tests { 
   public class Tests { 
      [Fact] 
      public void Test1() { 
         Assert.True(true); 
      } 
   } 
}

Voici la mise en œuvre de project.json fichier.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "debugType": "portable" 
   }, 
   "dependencies": { 
      "System.Runtime.Serialization.Primitives": "4.1.1", 
      "xunit": "2.1.0", 
      "dotnet-test-xunit": "1.0.0-rc2-192208-24" 
   }, 
   "testRunner": "xunit", 
   "frameworks": { 
      "netcoreapp1.0": { 
         "dependencies": { 
            "Microsoft.NETCore.App": { 
               "type": "platform", 
               "version": "1.0.1" 
            }
         }, 
         "imports": [ 
            "dotnet5.4", 
            "portable-net451+win8" 
         ] 
      } 
   } 
}

Dans project.json, la dépendance la plus importante au framework de test est le xunit, qui apporte l'attribut Fact. Il apporte le cadre de test et les API pour les tests avec xunit.

Nous avons également le dotnet-test-xunit, il s'agit d'un adoptant afin que xunit puisse fonctionner avec .NET Core, en particulier avec dotnet testutilitaire de ligne de commande. Ensuite, vous verrez letestRunner qui exécutera xunit et vous pouvez également voir le netcoreapp1.0 cadre.

Vous verrez la dépendance .NETCore.App ci-dessous.

Pour exécuter le test dans Visual Studio, ouvrons l'Explorateur de tests à partir du Test → Window → Test Explorer option de menu.

Et vous pouvez voir que Visual Studio détecte automatiquement le test. Le nom du test se compose denamespace.className.TestMethodName. Cliquons maintenant surRun All button in Test Explorer.

Il créera d'abord le code et exécutera le test et vous verrez le temps total pris par le test. Modifions la méthode de test afin que nous puissions voir la sortie lorsque le test échoue.

using System; 
using Xunit; 
  
namespace Tests { 
   public class Tests { 
      [Fact] 
      public void Test1() { 
         Assert.True(false); 
      } 
   } 
}

Exécutons à nouveau le test en cliquant sur le Run All lien du bouton.

Vous pouvez maintenant voir le test échec.

Dans ce chapitre, nous allons tester notre StringLibrary et pour ce faire, nous devons réorganiser nos projets afin de pouvoir suivre la convention par défaut.

Ouvrons le global.json fichier.

{ 
   "projects": [ "src", "test" ], 
   "sdk": { 
      "version": "1.0.0-preview2-003131" 
   } 
}

En haut de ce fichier, vous verrez les paramètres du projet et il configure un dossier tel que src et test par défaut.

Comme par convention, nous devons avoir des projets dans ces dossiers, il s'agit de la nouvelle convention et qui sera utilisée dans le cadre de .NET Core.

Dans l'Explorateur de solutions, vous pouvez voir que le projet de console et le projet de bibliothèque se trouvent dans le src dossier pendant que le projet de test est à l'intérieur test dossier.

Et la structure des projets dans l'Explorateur de solutions ne représente pas l'emplacement physique des projets sur le disque. Ouvrons maintenant le dossier Solution et vous verrez queStringLibrary le projet n'est pas à l'intérieur du src dossier.

Vous pouvez voir que les deux src et test les dossiers correspondent à la convention spécifiée dans le global.jsonfichier. Cependant, nous avons un projet StringLibrary qui n'est pas conventionnel. Ajoutons maintenant leStringLibrary projet à l'intérieur du src dossier.

Dans le dossier src, nous avons deux projets et nous devons résoudre le problème afin que nous puissions utiliser tous les projets correctement. Revenons à Visual Studio et cliquez avec le bouton droit sur le projet StringLibrary et sélectionnez l'option Supprimer. Il ne le supprimera pas, mais ne supprimera que le projet.

Maintenant, faites un clic droit sur le dossier src et sélectionnez Add → Existing Project…

Accédez au projet StringLibrary qui se trouve maintenant dans le src dossier, sélectionnez le StringLibrary.csproj fichier et cliquez Open.

Nous devons maintenant supprimer la référence de StringLibrary du project.json fichier de l'application console.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "emitEntryPoint": true 
   }, 
   "dependencies": { 
      "Microsoft.NETCore.App": { 
         "type": "platform", 
         "version": "1.0.1" 
      }, 
      "NuGet.CommandLine": "3.5.0", 
      "System.Runtime.Serialization.Json": "4.0.3" 
   }, 
   "frameworks": { 
      "netcoreapp1.0": { 
         "dependencies": { }, 
         "imports": "dnxcore50" 
      } 
   } 
}

Enregistrez les modifications, puis ajoutez une référence de StringLibrary à nouveau dans votre projet de console.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "emitEntryPoint": true 
   }, 
   "dependencies": { 
      "Microsoft.NETCore.App": { 
         "type": "platform", 
         "version": "1.0.1" 
      }, 
   "NuGet.CommandLine": "3.5.0", 
      "System.Runtime.Serialization.Json": "4.0.3" 
   }, 
   "frameworks": { 
      "netcoreapp1.0": { 
         "dependencies": { 
            "StringLibrary": { 
               "target": "project" 
            } 
         }, 
         "imports": "dnxcore50" 
      } 
   } 
}

Maintenant, tout devrait fonctionner à nouveau et vous pouvez construire StringLibrary et alors FirstApp(projet de console) sans aucune erreur. Testons maintenant la fonctionnalité StringLibrary en utilisant xunit. Nous devons ajouter une référence à StringLibrary dans notre projet de test. Cliquez avec le bouton droit sur le projet Références du projet StringLibraryTests et sélectionnez Ajouter une référence…

Cliquez sur OK qui ajoutera une référence de StringLibraryà notre projet de test. Remplaçons maintenant le code suivant dans leTests.cs fichier.

using System; 
using Xunit; 
using StringLibrary; 
  
namespace Tests { 
   public class Tests { 
      [Fact] 
      public void StartsWithUpperCaseTest() { 
         string input = "Mark"; 
         Assert.True(input.StartsWithUpper()); 
      } 
      [Fact] 
      public void StartsWithLowerCaseTest() { 
         string input = "mark"; 
         Assert.True(input.StartsWithLower()); 
      } 
      [Fact] 
      public void StartsWithNumberCaseTest() { 
         string input = "123"; 
         Assert.True(input.StartsWithNumber()); 
      } 
   } 
}

Vous pouvez voir que nous avons trois méthodes de test qui testeront la fonctionnalité de StringLibrary. Cliquons sur leRun All lien et vous verrez la sortie suivante dans l'Explorateur de tests.

Vous pouvez également exécuter les tests à partir de la ligne de commande. Ouvrons l'invite de commande et exécutons ledotnet test commander.

Dans ce chapitre, nous aborderons le Managed Extensibility Framework (MEF). MEF peut être utilisé pour l'extensibilité de plug-in tiers, ou il peut apporter les avantages d'une architecture de type plug-in faiblement couplée aux applications classiques.

  • MEF est une bibliothèque permettant de créer des applications légères et extensibles.

  • Il permet aux développeurs d'applications de découvrir et d'utiliser des extensions sans aucune configuration requise.

  • MEF fait partie intégrante du .NET Framework 4 et est disponible partout où le .NET Framework est utilisé, ce qui améliore la flexibilité, la maintenabilité et la testabilité des grandes applications.

  • Vous pouvez utiliser MEF dans vos applications clientes, qu'elles utilisent Windows Forms, WPF ou toute autre technologie, ou dans les applications serveur qui utilisent ASP.NET.

  • MEF a été porté comme Microsoft.Composition à .NET Core également mais partiellement.

  • Seulement System.Composition est porté, et System.ComponentModel.Compositionn'est pas encore disponible. Cela signifie que nous n'avons pas les catalogues qui peuvent charger des types à partir d'assemblys dans un répertoire.

Dans ce chapitre, nous apprendrons uniquement comment utiliser MEF dans l'application .NET Core.

Laissez-nous comprendre un exemple simple dans lequel nous utiliserons MEF dans l'application console .NET Core. Créons maintenant un nouveau projet de console .NET Core.

Dans le volet gauche, sélectionnez Templates → Visual C# → .NET Core, puis dans le volet central, sélectionnez Application console (.NET Core).

Entrez le nom du projet dans le champ Nom et cliquez sur OK.

Une fois le projet créé, nous devons ajouter une référence de Microsoft.Composition afin de pouvoir utiliser MEF. Pour ce faire, faites un clic droit sur le projet dans l'Explorateur de solutions etManage NuGet Packages…

Rechercher Microsoft.Composition et cliquez Install.

Clique le OK bouton.

Clique le I Accept bouton.

Une fois l'installation terminée, vous trouverez une erreur dans les références.

Ouvrons le project.json fichier.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "emitEntryPoint": true 
   }, 
  
   "dependencies": { 
      "Microsoft.Composition": "1.0.30", 
      "Microsoft.NETCore.App": { 
         "type": "platform", 
         "version": "1.0.1" 
      } 
   }, 
  
   "frameworks": { 
      "netcoreapp1.0": { 
         "imports": "dnxcore50" 
      } 
   } 
}

Vous pouvez voir que le Microsoft.Composition la dépendance est ajoutée, mais le problème est que ce package n'est pas compatible avec dnxcore50. Nous devons donc importerportablenet45+win8+wp8+wpa81. Laissez-nous maintenant remplacer votreproject.json fichier avec le code suivant.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "emitEntryPoint": true 
   }, 
   "dependencies": { 
      "Microsoft.Composition": "1.0.30", 
      "Microsoft.NETCore.App": { 
         "type": "platform", 
         "version": "1.0.1"
      } 
   }, 
   "frameworks": { 
      "netcoreapp1.0": { 
         "imports": "portable-net45+win8+wp8+wpa81" 
      } 
   } 
}

Enregistrez ce fichier et vous verrez que l'erreur est corrigée.

Si vous développez les références, vous verrez une référence de Microsoft.Composition.

Nous devons d'abord créer une interface qui doit être exportée, implémenter l'interface et décorer la classe avec l'attribut d'exportation. Ajoutons maintenant une nouvelle classe.

Entrez le nom de votre classe dans le champ Nom et cliquez sur Add.

Ajoutons le code suivant dans le PrintData.cs fichier.

using System; 
using System.Collections.Generic; 
using System.Composition; 
using System.Linq; 
using System.Threading.Tasks; 
  
namespace MEFDemo { 
   public interface IPrintData { 
      void Send(string message); 
   } 
   [Export(typeof(IPrintData))] 
   public class PrintData : IPrintData { 
      public void Send(string message) { 
         Console.WriteLine(message); 
      } 
   } 
}

Comme mentionné ci-dessus, les catalogues ne sont pas disponibles dans l'espace de noms Microsoft.Composition. Ainsi, il chargera tous les types de l'assembly avec l'attribut d'exportation et s'attachera à l'attribut d'importation comme indiqué dans la méthode Compose dans le fichier Program.cs.

using System; 
using System.Collections.Generic; 
using System.Composition; 
using System.Composition.Hosting; 
using System.Linq; 
using System.Reflection; 
using System.Threading.Tasks; 
  
namespace MEFDemo { 
   public class Program { 
      public static void Main(string[] args) { 
         Program p = new Program(); 
         p.Run(); 
      } 
      public void Run() { 
         Compose(); 
         PrintData.Send("Hello,this is MEF demo"); 
      } 
      [Import] 
      public IPrintData PrintData { get; set; } 
      
      private void Compose() { 
         var assemblies = new[] { typeof(Program).GetTypeInfo().Assembly }; 
         var configuration = new ContainerConfiguration() 
            .WithAssembly(typeof(Program).GetTypeInfo().Assembly); 
         
         using (var container = configuration.CreateContainer()) { 
            PrintData = container.GetExport<IPrintData>(); 
         } 
      } 
   } 
}

Lançons maintenant votre application et vous verrez qu'elle s'exécute en instanciant le PrintData classe.

Pour en savoir plus sur MEF, visitons l'URL suivante https://msdn.microsoft.com/en-us/library/dd460648%28v=vs.110%29.aspx pour plus de détails.

Dans ce chapitre, nous allons comprendre les fonctionnalités à venir de .NET Core. Nous allons commencer avec les outils de ligne de commande .NET en ouvrant l'URL suivante dans le navigateurhttps://github.com/dotnet/cli

Pour en savoir plus sur la progression, vous pouvez télécharger la dernière version du SDK .NET Core en faisant défiler vers le bas et vous verrez la section Installer et binaires.

Vous pouvez voir la dernière version des outils de prévisualisation pour différents systèmes d'exploitation, laissez-nous sélectionner le programme d'installation en fonction de votre système d'exploitation.

Nous travaillons sur l'aperçu 1 de .NET Core 2.0.

Examinons maintenant notre outillage actuel en ouvrant l'invite de commande et exécutons la commande suivante.

dotnet --info

Vous verrez des informations sur la version actuellement installée des outils de ligne de commande .NET sur votre système, comme indiqué ci-dessous.

Vous pouvez voir que nous avons actuellement l'outillage de l'aperçu 2. Exécutons maintenant la commande suivante pour voir à propos de lanew commander.

dotnet help new

Pour le nouveau langage de commande du projet, vous pouvez sélectionner comme C # et F # et le type de projet, etc.

Voyons maintenant les changements dans la dernière version de .NET Core. Une fois le programme d'installation téléchargé, double-cliquez dessus pour l'installer. Cliquez sur Installer.

La capture d'écran suivante montre le processus d'installation.

Cela lancera le processus d'installation. Une fois l'installation terminée, fermez cette boîte de dialogue.

Ouvrez l'invite de commande et exécutez la commande suivante.

dotnet --info

Vous verrez des informations sur la version actuellement installée des outils de ligne de commande .NET sur votre système, comme indiqué ci-dessous.

Vous pouvez maintenant voir que nous avons l'outillage preview1 de .NET Core 2. Exécutons maintenant le code suivant dans l'invite de commandes pour voir la nouvelle commande dans .NET Core 2 preview1.

dotnet help new

La commande vous aide également à télécharger des packages dans le cache de packages.

La commande ouvre la page Web suivante qui contient des informations sur la nouvelle commande dans .NET Core 2 preview1.

Laissez-nous faire défiler vers le bas, vous pouvez maintenant voir que nous pouvons créer l'application .NET Core avec plus de modèles.

Nous pouvons maintenant créer mstest, web, mvc et webapi projets ainsi qu'en utilisant la ligne de commande.

Le .NET Core a décidé de supprimer project.json et de revenir à MSBuild et * .csproj. C'est quelque chose qui s'est déjà produit dans l'outillage .Net Core 2.0 preview1 qui vient d'être publié. C'est assez décevant, car le project.json était une bouffée d'air frais. Cependant, il est compréhensible et présente également de nombreux avantages.

Parlons maintenant des avantages que le changement apporte -

  • Cela faciliterait la transition des solutions Visual Studio existantes vers .NET Core.

  • C'est un changement énorme et cela permettra également de tirer parti des investissements existants dans CI / RM autour de MSBuild.

  • Lors de la construction dans MSBuild, nous pouvons penser à la compilation incrémentielle, à la résolution des dépendances de compilation, à la gestion de la configuration, etc.

  • Beaucoup de travail est nécessaire pour expédier dotnet cli à temps, car il ne s'agit plus seulement d'ASP.NET Core, mais aussi d'applications de console, d'applications UWP, etc.

Voici les modifications apportées à MSBuild et * .csproj -

  • Le fichier Project.json (* .xproj) sera remplacé par MSBuild (* .csproj).

  • Les fonctionnalités de project.json commenceront à être fusionnées dans le fichier * .csproj.

  • On ne sait pas encore ce qu'ils vont faire à propos de la liste des paquets, mais il a été mentionné qu'ils pourraient la garder sous json sous nuget.json ou fusionnez-le dans le *.csproj.

  • On suppose que cette transition devrait être fluide et potentiellement automatique si vous utilisez Visual Studio.

Avantages de MSBuild

  • MSBuild est open source et disponible sur GitHub et est appelé à devenir entièrement multi-plateforme.

  • MSBuild simplifiera et réduira considérablement la structure du *.csproj.

  • Microsoft introduit également un nouveau système de projet qui permettra de nombreux scénarios sans avoir besoin de Visual Studio et les détails sont donnés sur cette URL https://github.com/dotnet/roslyn-project-system/.

  • L'objectif est que même avec la configuration MSBuild, l'utilisation des builds et des projets sera aussi transparente dans Visual Studio IDE qu'en dehors de celui-ci.

MSBuild contre project.json

Créons maintenant un nouveau projet de console avec les outils .NET Core preview2 en exécutant la commande suivante.

dotnet new -t console

Pour voir tous les fichiers créés dans ce projet, exécutez le dir commander.

Vous pouvez voir que deux fichiers sont créés, Program.cs et project.json fichier.

Créons maintenant une application console avec les outils .NET Core 2 preview1 en exécutant la commande suivante.

dotnet new console

Pour voir tous les fichiers créés dans ce projet, exécutez le dircommander. Vous pouvez voir que trois fichiers sont créés,Program.cs, NuGet.config et MSBuild.csproj au lieu du fichier project.json.

Comparons maintenant project.json et MSBuild.csproj fichiers côte à côte.

À gauche, nous avons le fichier au format json tandis qu'à droite, le fichier est au format XML. Vous pouvez voir que dans le fichier project.json, dans la section des dépendances, il y anetcoreapp1.0, tandis que dans le fichier MSBuild.csproj, vous verrez le netcoreapp2.0.

Dans ce chapitre, nous verrons comment restaurer et créer votre fichier MSBuild (* .csproj) à l'aide de l'utilitaire de ligne de commande. Pour voir quelles commandes sont disponibles dans .NET Core 2.0 preview 1, exécutons la commande suivante.

dotnet help

Vous verrez toutes les commandes comme new, restore, build, etc.

Voici l'implémentation par défaut dans Program.cs fichier.

using System;  
namespace MSBuild { 
   class Program { 
      static void Main(string[] args) { 
         Console.WriteLine("Hello World!"); 
      } 
   } 
}

Exécutons maintenant la commande suivante pour voir la progression.

dotnet build

Vous verrez beaucoup d'erreurs. Ces erreurs doivent être corrigées.

Exécutons maintenant la commande suivante.

dotnet restore

Vous pouvez voir que tous les packages sont restaurés. Certains nouveaux dossiers et fichiers ont également été générés.

Pour voir la structure des répertoires, exécutons la commande suivante.

tree /f

Voici la structure des répertoires -

Reconstruisons maintenant le projet en exécutant à nouveau la commande suivante.

dotnet build

Maintenant, votre projet sera généré avec succès sans aucune erreur et MSBuild.dll est également créé.

Pour voir la sortie, exécutons la commande suivante -

dotnet run

Vous pouvez voir la sortie suivante sur votre console.

Dans ce chapitre, nous allons migrer l'application console qui contient le project.json système de création de fichiers au lieu de MSBuild (*.csproj). Donc, nous avons un ancien projet qui contient les fichiers suivants.

Maintenant, la question est: pourquoi avons-nous besoin de migration? Ce projet est créé à l'aide des outils .NET Core 1.0 preview 2 et nous avons maintenant installé les outils .NET Core 2.0 preview 1. Maintenant, lorsque vous créez cette application à l'aide de l'utilitaire de ligne de commande .NET Core 2.0, vous verrez l'erreur suivante.

C'est parce que le project.jsonbuild system n'est plus disponible dans .NET Core 2.0, nous avons donc besoin d'une migration pour qu'il puisse fonctionner correctement. Pour voir les commandes disponibles, exécutons la commande suivante.

dotnet help

Dans la section des commandes, vous pouvez voir les différentes commandes et vous pouvez également voir les migrate qui fera migrer un projet basé sur project.json vers un projet basé sur MSBuild.

Exécutons maintenant la commande suivante.

dotnet migrate

Vous verrez un résumé du processus de migration et ici vous pouvez également voir qu'un projet est migré avec succès.

Voyons maintenant la structure des répertoires en utilisant la commande suivante.

tree /f

Vous verrez maintenant le fichier * .csproj avec le fichier Program.cs dans le répertoire racine du projet et project.json est déplacé vers le dossier de sauvegarde.

Ouvrons le console.csprojfichier. Vous pouvez maintenant restaurer et générer ce projet à l'aide du système MSBuild en exécutant la commande suivante.

dotnet restore

Vous pouvez maintenant voir que tous les packages sont restaurés.

Vous pouvez maintenant créer votre projet avec la commande suivante.

dotnet build

Vous pouvez maintenant voir que le projet est généré avec succès à l'aide de MSBuild et console.dll est également généré dans ..\bin\Debug\netcoreapp1.0 dossier.

La capture d'écran suivante montre la structure du répertoire et les fichiers.