- [C#] Hướng dẫn fix lỗi Visual Studio 2022 not Support Target Net Framework 4.5.2
- [C#] Giới thiệu thư viện Sunny UI thiết kế giao diện trên Winform
- [DATABASE] Hướng dẫn thêm và cập nhật Extended Property Column trong Table Sqlserver
- [DEVEXPRESS] Hướng dẫn sử dụng Vertical Gridview để hiển thị thông tin sản phẩm
- [C#] Hướng dẫn sử dụng Json Schema để Validate chuỗi string có phải json
- [C#] Hướng dẫn sử dụng công cụ Clean Code trên Visual Studio
- [C#] Hướng dẫn Drag and Drop File vào RichTextBox
- [C#] Hướng dẫn tạo hiệu ứng Karaoke Text Effect Winform
- [C#] Sử dụng thư viện ZedGraph vẽ biểu đồ Line, Bar, Pie trên Winform
- [DATABASE] Hướng dẫn sort sắp xếp địa chỉ IP trên sqlserver sử dụng hàm PARSENAME
- [C#] Theo dõi sử kiện process Start hay Stop trên Winform
- [ASP.NET] Chia sẻ source code chụp hình sử dụng camera trên website
- [C#] Chạy ứng dụng trên Virtual Desktop (màn hình ảo) Winform
- [C#] Mã hóa và giải mã Data Protection API trên winform
- [C#] Hướng dẫn tạo Gradient Background trên Winform
- [DATABASE] Hướng dẫn convert Epoch to DateTime trong sqlserver
- [DATABASE] Hướng dẫn sử dụng STRING_AGG và CONCAT_WS trong sqlserver 2017
- [C#] Hướng dẫn Copy With All Property in Class Object
- [DEVEXPRESS] Hướng dẫn load Json DataSource vào GridView
- [C#] Hướng dẫn tạo chữ ký trên winform Signature Pad
[C#] Giới thiệu thư viện Autofac Dependency Injection
Xin chào các bạn, bài viết hôm nay mình sẻ tiếp tục giới thiệu đến các bạn thư viện Autofac Dependency Injection trong lập trình C#, winform.
[C#] Using Autofac Dependency Injection
Trong ngôn ngữ lập trình hướng đối tượng, IOC hay DI pattern là một trong những khái niệm quan trọng.
Nó chống lại sự phụ thuộc lẫn nhau giữa các object. Nếu quản lý bằng cách khởi tạo đối tượng thông thường, sẽ khó khăn khi project của bạn ngày càng lớn.
Trong lập trình ứng dụng, nếu ứng dụng của bạn sử dụng nhiều loại cơ sở dữ liệu trong cùng một project như:
Sqlite để lưu cấu hình, Sqlserver, Mysql hay Orcale chẳng hạn.
Thì khi các bạn muốn thay đổi connection đến loại cơ sở dữ liệu nào thì chúng ta sẽ sử dụng Autofac để quản lý và thay đổi dễ dàng.
Đầu tiên các bạn import thư viện Autofac từ Nuget Console với lệnh sau:
PM>Install-Package Autofac -Version 6.1.0
Full source code Autofac C#:
using Autofac;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace AutoFacDemo
{
class Program
{
static void Main(string[] args)
{
AppService.Connection.Connect();
AppService.Connection.Command("Insert");
Console.ReadLine();//Wait
}
public interface IConnection
{
void Connect();
void Command(string command);
}
public class MySqlConnection : IConnection
{
public void Command(string command)
{
Console.Write("Execute MySql command: {0}", command);
}
public void Connect()
{
Console.WriteLine("Connect to MySql Server...");
}
}
public class SqlConnection : IConnection
{
public void Command(string command)
{
Console.Write("Execute Sql command: {0}", command);
}
public void Connect()
{
Console.WriteLine("Connect to Sql Server...");
}
}
public static class AppService
{
static IContainer Container { get; set; }
static AppService()
{
ContainerBuilder builder = new ContainerBuilder();
builder.RegisterType<SqlConnection>().As<IConnection>();
// builder.RegisterType<MySqlConnection>().As<IConnection>(); //Change your instance you want to create
Container = builder.Build();
}
public static IConnection Connection => Container.Resolve<IConnection>();
}
}
}
Kết quả khi chạy ứng dụng:
Trên đây là cơ bản việc sử dụng thư viện Autofac, các bạn có thể tham khảo cụ thể ở tài liệu document tại trang chủ Autofac:
Thanks for watching!