一、什么是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
}