首頁 > 軟體

.NET Core使用APB vNext框架入門教學

2022-02-18 10:02:09

快速入門案例

.NET Core 控制檯應用

1. 安裝 ABP 框架核心依賴

Install-Package Volo.Abp.Core -Version 3.3.2

2. 新建 ABP 應用的啟動模組

HelloAbpModule.cs

using Volo.Abp.Modularity;

namespace HelloAbp
{
    /// <summary>
    /// 啟動模組
    /// </summary>
    public class HelloAbpModule : AbpModule
    {

    }
}

3. 新建服務,並註冊到啟動模組中

HelloWorldService.cs

using System;
using Volo.Abp.DependencyInjection;

namespace HelloAbp
{
    /// <summary>
    /// TODO: ABP 註冊服務方式一: 繼承介面
    ///     ISingletonDependency、IScopedDependency、ITransientDependency
    /// </summary>
    public class HelloWorldService : ITransientDependency
    {
        public void Run()
        {
            Console.WriteLine($"{nameof(HelloAbpModule)}-{nameof(HelloWorldService)}: Hello World!");
        }
    }
}

4. 根據啟動模組建立 ABP應用,呼叫應用中註冊的服務方法

Program.cs

using System;
using Microsoft.Extensions.DependencyInjection;
using Volo.Abp;

namespace HelloAbp
{
    class Program
    {
        static void Main(string[] args)
        {
                // 根據啟動模組建立 abp 應用
                var application = AbpApplicationFactory.Create<HelloAbpModule>();
                // 初始化 abp 應用
                application.Initialize();
                // 獲取應用中註冊的服務
                var service = application.ServiceProvider.GetService<HelloWorldService>();
                // 呼叫應用中的服務方法 
                service.Run();

            Console.ReadKey();
        }
    }
}

ASP.NET Core Web 應用程式

1. 安裝 ABP 框架核心依賴

Install-Package Volo.Abp.Core -Version 3.3.2
Install-Package Volo.Abp.AspNetCore.Mvc -Version 3.3.2

2.新建 ABP 應用的啟動模組

AppModule.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.Hosting;
using Volo.Abp;
using Volo.Abp.AspNetCore.Mvc;
using Volo.Abp.Modularity;

namespace HelloWebAbp
{
    /// <summary>
    /// 啟動模組
    ///     TODO: 1.在啟動模組中設定 ASP.NET Core Web 程式的管道,就需要定義對 ASP.NET Core Mvc模組的依賴
    /// </summary>
    [DependsOn(typeof(AbpAspNetCoreMvcModule))]
    public class AppModule : AbpModule
    {
        /// <summary>
        /// 應用初始化方法
        ///     TODO: 2.重寫 ABP 應用的初始化方法,用來構建 ASP.NET Core 應用程式的中介軟體管道
        /// </summary>
        /// <param name="context"></param>
        public override void OnApplicationInitialization(ApplicationInitializationContext context)
        {
            // base.OnApplicationInitialization(context);

            var app = context.GetApplicationBuilder();
            var env = context.GetEnvironment();

            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }

            app.UseRouting();

            // TODO: 5.將 程式應用的端點設定 修改為 ABP 應用的端點設定
            app.UseConfiguredEndpoints();
        }
    }
}

3. 註冊 ABP 啟動模組,並初始化 ABP 應用

Startup.cs

using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;

namespace HelloWebAbp
{
    /// <summary>
    /// 程式啟動類
    /// TODO: 3. 在 Startup 類中,完成對 ABP 應用的初始化
    /// </summary>
    public class Startup
    {
        // This method gets called by the runtime. Use this method to add services to the container.
        // For more information on how to configure your application, visit https://go.microsoft.com/fwlink/?LinkID=398940
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddApplication<AppModule>();
        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
        {
            app.InitializeApplication();
        }
    }
}

4. 新建控制器,測試 ABP 應用執行狀態

HomeController.cs

using Microsoft.AspNetCore.Mvc;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Volo.Abp.AspNetCore.Mvc;

namespace HelloWebAbp.Controllers
{
    /// <summary>
    /// 控制器
    ///     TODO: 4. 繼承 Abp 框架中的基礎類別控制器(提供了一些便捷的服務和方法)
    /// </summary>
    public class HomeController : AbpController
    {
        public IActionResult Index()
        {
            return Content("Hello world!");
        }
    }
}

各個擊破案例

ABP應用中的模組可以有很多個,但是啟動模組只能有一個;

ABP應用中的每個模組之間沒有必然的聯絡;

ABP應用中每個模組註冊的服務,都註冊到了ABP應用的全域性容器中;

ABP應用中的模組也分為兩種型別:應用程式模組(業務實現)和框架模組(技術實現);

ABP應用中最頂層的模組是啟動模組,最後被載入的也是啟動模組。

在模組中註冊自定義服務

HelloAbpModule.cs

using System;
using System.Collections.Generic;
using System.Text;
using Microsoft.Extensions.DependencyInjection;
using Volo.Abp;
using Volo.Abp.Modularity;

namespace HelloAbp
{
    /// <summary>
    /// 啟動模組
    /// </summary>
    public class HelloAbpModule : AbpModule
    {
        // TODO: 重寫 ABP 模組的服務設定方法,向模組中註冊自定義的服務
        public override void ConfigureServices(ServiceConfigurationContext context)
        {
            base.ConfigureServices(context);

            // TODO: ABP 註冊服務方式二: 模組註冊
            context.Services.AddTransient<HelloWorldService>();
        }
    }
}

小結

初始化ABP模組

  • 1.註冊ABP基礎設施與核心服務(模組系統相關)
  • 2.載入整個應用的所有模組,按照依賴性排序
  • 3.按順序遍歷所有模組,執行每一個模組的設定方法
  • 4.按順序遍歷所有模組,執行每一個模組的初始化方法

使用標籤屬性註冊自定義服務

HelloWorldService.cs

using System;
using System.Collections.Generic;
using System.Text;
using Microsoft.Extensions.DependencyInjection;
using Volo.Abp.DependencyInjection;

namespace HelloAbp
{
    /// <summary>
    /// TODO: ABP 註冊服務方式三: 特性標籤
    ///     ServiceLifetime.Singleton、ServiceLifetime.Scoped、ServiceLifetime.Transient
    /// </summary>
    [Dependency(ServiceLifetime.Transient)]
    public class HelloWorldService
    {
        public void Run()
        {
            Console.WriteLine($"{nameof(HelloAbpModule)}-{nameof(HelloWorldService)}: Hello World!");
        }
    }
}

ABP 專案中使用 Autofac

1. 安裝 Autofac 模組

Install-Package Volo.Abp.Autofac -Version 3.3.2

2. 在模組中建立對 Autofac 模組的依賴

HelloAbpModule.cs

using System;
using System.Collections.Generic;
using System.Text;
using Microsoft.Extensions.DependencyInjection;
using Volo.Abp;
using Volo.Abp.Autofac;
using Volo.Abp.Modularity;

namespace HelloAbp
{
    /// <summary>
    /// 啟動模組
    /// </summary>
    // TODO: 使用 Autofac 第三方依賴注入框架(提供了更多的高階特性)
    [DependsOn(typeof(AbpAutofacModule))]
    public class HelloAbpModule : AbpModule
    {
        public override void ConfigureServices(ServiceConfigurationContext context)
        {
            base.ConfigureServices(context);

            context.Services.AddTransient<HelloWorldService>();
        }
    }
}

3. 在ABP應用建立時整合 Autofac

Program.cs

using System;
using Microsoft.Extensions.DependencyInjection;
using Volo.Abp;

namespace HelloAbp
{
    class Program
    {
        static void Main(string[] args)
        {
            {
                // 根據啟動模組建立 abp 應用
                var application = AbpApplicationFactory.Create<HelloAbpModule>(options =>
                {
                    // 整合 Autofac 
                    options.UseAutofac();
                });
                // 初始化 abp 應用
                application.Initialize();
                // 獲取應用中註冊的服務
                var service = application.ServiceProvider.GetService<HelloWorldService>();
                // 呼叫應用中的服務方法 
                service.Run();
            }

            Console.WriteLine("Hello World!");
            Console.ReadKey();
        }
    }
}

完整案例程式碼

AbpSample

到此這篇關於.NET Core使用APB vNext框架入門教學的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com