您的位置:

ABPvNext教程详解

一、什么是ABPvNext?

ABPvNext(ASP.NET Boilerplate)是一个ASP.NET Core 应用程序的开发框架,它以最佳实践为基础,旨在提高应用程序的生产力和质量。

ABPvNext不仅仅是一个框架,它同时也是一套完整的应用程序开发解决方案。它提供了许多可供使用的功能,如多租户和多语言支持、身份验证和授权、实体框架、自动化测试等。

二、ABPvNext的核心功能

ABPvNext提供了许多核心功能,包括实体框架、MVC框架、身份验证和授权等等。

1.实体框架

ABPvNext的实体框架提供了一个强大和灵活的对象关系映射(ORM)和实体框架。您可以使用ABPvNext动态创建实体、修改实体、查询实体和删除实体。它还允许您使用以下技术访问数据: Dapper、Entity Framework Core和NHibernate。

以下是使用ABPvNext实体框架的示例代码:

public interface IBookRepository : IRepository<Book, Guid>
{
    Task<List<Book>> GetBooksAsync(string name);
}

2.MVC框架

ABPvNext的MVC框架提供了一组用于构建Web应用程序的基础设施。它使用标准的ASP.NET Core MVC技术来构建Web应用程序,并具有可定制的路由、参数验证和错误处理等功能。

以下是使用ABPvNext MVC框架的示例代码:

[HttpPost]
public async Task<ActionResult> Create([FromBody] CreateBookInput input)
{
    var book = ObjectMapper.Map<Book>(input);
    await _bookManager.CreateAsync(book);
    return CreatedAtAction("Get", new { id = book.Id }, book);
}

3.身份验证和授权

ABPvNext提供了强大的身份验证和授权功能,支持多种身份验证机制,如用户名/密码、OAuth、OpenId Connect、LDAP、Windows身份验证和Cognito身份提供程序等。它还提供了一组用于授权的API,以及支持更细粒度授权的自定义策略和声明。

以下是使用ABPvNext身份验证和授权功能的示例代码:

[Authorize]
public async Task<ActionResult> Update(Guid id, [FromBody] UpdateBookInput input)
{
    var book = await _bookManager.GetAsync(id);
    if (book == null)
    {
        return NotFound();
    }

    ObjectMapper.Map(input, book);
    await _bookManager.UpdateAsync(book);
    return NoContent();
}

三、ABPvNext的应用程序模块化

ABPvNext支持应用程序的模块化。每个模块都是一个可插入应用程序的组件。每个模块都有自己的Web界面(或API接口)和实现业务逻辑的服务层。在ABPvNext中,模块是通过NuGet包进行分发。

以下是使用ABPvNext模块化的示例代码:

[DependsOn(typeof(AbpSettingManagementHttpApiModule))]
public class MyModule : AbpModule
{
    public override void ConfigureServices(ServiceConfigurationContext context)
    {
        Configure<AbpDbContextOptions>(options =>
        {
            options.UseSqlServer();
        });
    }
 
    public override void OnApplicationInitialization(ApplicationInitializationContext context)
    {
        var app = context.GetApplicationBuilder();
        app.UseHttpsRedirection();
        app.UseRouting();
        app.UseAuthentication();
        app.UseAuthorization();
        app.UseEndpoints(endpoints =>
        {
            endpoints.MapControllers();
        });
    }
}

四、ABPvNext的多租户支持

ABPvNext的多租户支持使您能够为多个客户提供托管服务。它允许为每个租户提供独立的数据库,甚至可以使用不同的身份验证和授权提供程序。

以下是使用ABPvNext多租户支持的示例代码:

public class MyTenant : AbpTenant<Guid>
{
    public MyTenant(Guid id, string name) 
        : base(id, name)
    {
    }
 
    public string ConnectionString { get; set; }
}
 
public class MyTenantResolveContributor : TenantResolveContributorBase
{
    public override async Task ResolveAsync(ITenantResolveContext context)
    {
        var host = context.httpContextAccessor.HttpContext.Request.Host.Host;
        var tenant = await CreateTenantAsync(host);
        if (tenant != null)
        {
            context.Result = new TenantResolveResult(tenant);
        }
    }
    
    private async Task<MyTenant> CreateTenantAsync(string host)
    {
        var url = $"http://tenant1.api.example.com/tenant/{host}";
        var json = await _httpClient.GetStringAsync(url);
        var result = JsonConvert.DeserializeObject<MyTenant>(json);
        return result;
    }
}

五、ABPvNext的自动化测试

ABPvNext提供了一组自动化测试工具,包括单元测试和集成测试。它支持多种测试框架,如xUnit、NUnit和MS Test。使用ABPvNext的测试工具,您可以轻松地创建和运行测试套件,以确保应用程序的质量和稳定性。

以下是使用ABPvNext自动化测试的示例代码:

public class BookAppService_Tests : MyProjectApplicationTestBase
{
    private readonly IBookAppService _bookAppService;
    private readonly IRepository<Book, Guid> _bookRepository;
 
    public BookAppService_Tests()
    {
        _bookAppService = GetRequiredService<IBookAppService>();
        _bookRepository = GetRequiredService<IRepository<Book, Guid>>();
    }
 
    [Fact]
    public async Task Should_Get_All_Books()
    {
        var result = await _bookAppService.GetAllAsync(new GetAllBooksInput());
        result.Items.Count.ShouldBe(2);
    }
 
    // other tests
}