Kerangka Kerja Ekstensi yang Dikelola

Pada bab ini, kita akan membahas tentang Managed Extensibility Framework (MEF). MEF dapat digunakan untuk ekstensibilitas plugin pihak ketiga, atau dapat membawa manfaat dari arsitektur mirip plugin yang digabungkan secara longgar ke aplikasi biasa.

  • MEF adalah perpustakaan untuk membuat aplikasi yang ringan dan dapat diperluas.

  • Ini memungkinkan pengembang aplikasi untuk menemukan dan menggunakan ekstensi tanpa memerlukan konfigurasi.

  • MEF merupakan bagian integral dari .NETFramework 4, dan tersedia di mana pun .NETFramework digunakan yang meningkatkan fleksibilitas, kemampuan pemeliharaan, dan kemampuan pengujian aplikasi besar.

  • Anda dapat menggunakan MEF di aplikasi klien Anda, apakah mereka menggunakan Formulir Windows, WPF, atau teknologi lainnya, atau dalam aplikasi server yang menggunakan ASP.NET.

  • MEF telah diporting sebagai Microsoft.Composition ke .NET Core juga, tetapi sebagian.

  • Hanya System.Composition porting, dan System.ComponentModel.Compositionbelum tersedia. Artinya, kami tidak memiliki katalog yang dapat memuat tipe dari rakitan dalam sebuah direktori.

Pada bab ini, kita hanya akan mempelajari bagaimana kita dapat menggunakan MEF pada aplikasi .NET Core.

Mari kita pahami contoh sederhana di mana kita akan menggunakan MEF di aplikasi konsol .NET Core. Sekarang mari kita buat proyek konsol .NET Core baru.

Di panel kiri, pilih Templates → Visual C# → .NET Core dan kemudian di panel tengah, pilih Aplikasi Konsol (.NET Core).

Masukkan nama proyek di kolom Name dan klik OK.

Setelah proyek dibuat, kita perlu menambahkan referensi Microsoft.Composition agar kita dapat menggunakan MEF. Untuk melakukannya, mari kita klik kanan pada proyek di Solution Explorer danManage NuGet Packages…

Pencarian untuk Microsoft.Composition dan klik Install.

Klik OK tombol.

Klik I Accept tombol.

Saat penginstalan selesai, Anda akan menemukan kesalahan di Referensi.

Mari kita buka project.json mengajukan.

{ 
   "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" 
      } 
   } 
}

Anda dapat melihat bahwa file Microsoft.Composition ketergantungan ditambahkan, tetapi masalahnya adalah paket ini tidak kompatibel dengan dnxcore50. Jadi kita perlu mengimporportablenet45+win8+wp8+wpa81. Biarkan kami sekarang mengganti fileproject.json file dengan kode berikut.

{ 
   "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" 
      } 
   } 
}

Simpan file ini dan Anda akan melihat bahwa kesalahan sudah diperbaiki.

Jika Anda memperluas Referensi, maka Anda akan melihat referensi dari Microsoft.Composition.

Pertama kita perlu membuat antarmuka yang akan diekspor dan mengimplementasikan antarmuka dan menghias kelas dengan atribut export. Sekarang mari kita tambahkan kelas baru.

Masukkan nama untuk kelas Anda di kolom Name dan klik Add.

Mari kita tambahkan kode berikut di PrintData.cs mengajukan.

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); 
      } 
   } 
}

Seperti disebutkan di atas, Katalog tidak tersedia di Microsoft.Composition namespace. Jadi, ini akan memuat semua tipe dari Assembly dengan atribut export dan melampirkan ke atribut import seperti yang ditunjukkan pada metode Compose di file 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>(); 
         } 
      } 
   } 
}

Biarkan kami sekarang menjalankan aplikasi Anda dan Anda akan melihat bahwa itu berjalan dengan membuat instance PrintData kelas.

Untuk mempelajari lebih lanjut tentang MEF, mari kita kunjungi Url berikut https://msdn.microsoft.com/en-us/library/dd460648%28v=vs.110%29.aspx untuk lebih jelasnya.