[译]ABP框架v2.9已经发布

ABP框架v2.9已经发布

ABP框架ABP商业版2.9已经发布,这是3.0之前的最后一个版本!这篇文章将涵盖本次发布中的新增内容.

ABP框架2.9有哪些新增内容?

你可以中GitHub的发行说明中看到所有的变更.这篇文章将只包括重要特征/变更.

预编译Razor Pages

在之前的版本, 预构建的页面(为应用模块)和视图组件是在运行时编译. 现在,它们使用了预编译. 我们测量的应用程序启动时间(尤其是MVC UI)已经减少了50%以上.换句话说,它比之前的版本快两倍.速度变化也影响你第一次访问某一个页面时.

这是一个v2.8和v2.9启动应用程序模板的对比结果:

### v2.8

2020-06-04 22:59:04.891 +08:00 [INF] Starting web host.
2020-06-04 22:59:07.662 +08:00 [INF] Now listening on: https://localhost:44391
2020-06-04 22:59:17.315 +08:00 [INF] Request finished in 7756.6218ms 200 text/html;

Total: 12.42s

### v2.9

2020-06-04 22:59:13.720 +08:00 [INF] Starting web host.
2020-06-04 22:59:16.639 +08:00 [INF] Now listening on: https://localhost:44369
2020-06-04 22:59:18.957 +08:00 [INF] Request finished in 1780.5461ms 200 text/html;

Total: 5.24s

你不用做任何改动就能获得新方法带来的益处.重写UI页/组件和之前一样也能正常工作.我们将在v3.0中继续致力于性能上的提升.

组织单元系统

Identity模块现在有了呼声最高的功能: 组织单元!

组织单元系统用来在应用程序中创建分层组织树.这样你可以使用该组织树来授权应用程序中的数据和功能.

文档将很快到来......

新的Blob存储包

我们创建了一个新的Blob存储包用来存储任意二进制对象.它一般用于在应用程序中存储文件.这个包提供了一个抽象,因此任何应用程序或模块都能以存储提供器无关的方式来保存和获取文件.

目前实现了两个存储提供器:

Azure BLOB提供器将会在3.0中可用. 你可请求其他的云提供器或在GitHub库上提交你自己的贡献.

Blob存储系统的一个好处是,它允许你创建多个容器(每个容器是一个Blob存储),并为每个容器使用不同的存储提供器.

示例:使用默认的容器保存和取得一个字节数组

public class MyService : ITransientDependency
{
    private readonly IBlobContainer _container;

    public MyService(IBlobContainer container)
    {
        _container = container;
    }

    public async Task FooAsync()
    {
        //保存一个BLOB
        byte[] bytes = GetBytesFromSomeWhere();
        await _container.SaveAsync("my-unique-blob-name", bytes);

        //获取一个BLOB
        bytes = await _container.GetAllBytesAsync("my-unique-blob-name");
    }
}

它可以使用byte[]Stream对象.

示例:使用类型化(命名)容器来保存和获取stream

public class MyService : ITransientDependency
{
    private readonly IBlobContainer<TestContainer> _container;

    public MyService(IBlobContainer<TestContainer> container)
    {
        _container = container;
    }

    public async Task FooAsync()
    {
        //保存一个BLOB
        Stream stream = GetStreamFromSomeWhere();
        await _container.SaveAsync("my-unique-blob-name", stream);

        //获取一个BLOB
        stream = await _container.GetAsync("my-unique-blob-name");
    }
}

TestContainer只是一个用来标识容器的空类:

[BlobContainerName("test")] //指定容器的名字
public class TestContainer
{

}

类型化(命名)容器可被配置为使用不同的存储提供器而不是默认的.在开发可复用的模块时, 始终使用类型化的容器是一个很好的做法,这样最终应用程序可以为这个容器配置提供器,而不影响其他容器.

示例:为TestContainer配置文件系统提供器

Configure<AbpBlobStoringOptions>(options =>
{
    options.Containers.Configure<TestContainer>(configuration =>
    {
        configuration.UseFileSystem(fileSystem =>
        {
            fileSystem.BasePath = "C:\\MyStorageFolder";
        });
    });
});

查看blob存储文档以获取更多的信息.

Entity Framework Core的Oracle集成包

我们创建了一个Oralce集成包,这样你就可以为EF Core轻松地切换到Oracle.它已经为框架和预构建的模块进行了测试.

查看文档开始使用Oracle集成包.

自动判断数据库提供器

当你用EF Core开发一个可复用的应用程序模块时,你通常要将你的模块开发为DBMS无关的.但是,不同的DBMS有一些微小的(有时是很大的)区别.现在如何你执行基于DBMS的自定义映射,可以使用ModelBuilder.IsUsingXXX()扩展方法:

protected override void OnModelCreating(ModelBuilder modelBuilder)
{
    base.OnModelCreating(modelBuilder);

    modelBuilder.Entity<Phone>(b =>
    {
        //...
        if (modelBuilder.IsUsingPostgreSql()) //检查是否在使用PostgreSQL!
        {
            b.Property(x => x.Number).HasMaxLength(20);
        }
        else
        {
            b.Property(x => x.Number).HasMaxLength(32);
        }
    });
}

除了上面这种的傻傻的例子,你可以任意配置你的映射!

ABP CLI:翻译命令

abp translate是一个新的命令,当你的源代码库中包含多个JSON本地化文件时, 它可用来简化翻译本地化文件,

该命令的主要目的是翻译ABP框架的本地化文件(因为abp库在不同的文件中含有成千上万个本地化文件需要翻译).

非常感谢如果你使用这个命令将框架资源翻译为你的母语.

查看文档来学习如何使用它.也可查看贡献指南.

新的虚拟文件系统浏览器模块

感谢@liangshiw创建并贡献了一个新的模块用来浏览虚拟文件系统中的文件.它适用于MVC UI并显示所有应用程序中的虚拟文件.示例截图:

查看文档学习如何使用它.

示例应用程序:SignalR与分层架构

在分布式/分层架构中实施SignalR是具有挑战性的.我们创建了一个示例应用程序演示如何轻松地使用SignalR集成分布式事件总线系统

查看示例解决方案的源代码.

一篇正在路上的文章将深入地解释该解决方案.关注@abpframework的Twitter帐号.

一张文章中的图片,显示了该解决方案的通信图

关于gRPC

我们创建了一个示例应用程序来说明如何在基于ABP的应用程序中创建和使用gRPC端点.

查看GitHub上的源码.

我们本来计划为所有预构建的应用程序模块创建gRPC端点,但我们发现ASP.NET Core gRPC集成还不够成熟,不支持一些常见的部署场景.所以推迟到了下一个版本(更多内容查看此评论).但是,在你的应用程序中使用gRPC是非常标准的. ABP框架与gRPC没有问题.看一下示例应用程序.

其它

其它更新请查看GitHub发行说明.

ABP商业版2.9有哪些新增内容

与往常一样, 除了ABP框架所有这些功能以外,ABP商业版在本次发布还有一些额外的功能.本节介绍ABP商业版在2.9版本中的亮点.

组织单元管理UI

我们为组织单元创建了UI,管理ABP商业版Identity模块的成员和角色:

OU管理适用于MVC(Razor Pages)和Angular用户界面.

聊天模块Angular UI

我们在前一个版本介绍了新的聊天模块, 当时它只有ASP.NET Core MVC / Razor Pages UI. 现在它也包含了一个Angular UI选项.

聊天模块的截图 - 两个用户互相发消息

Easy CRM Angular UI

Easy CRM是建立在ABP商业版上的一个示例应用程序, 用来为ABP商业版客户提供一个相对复杂的应用程序.在2.7版本中,我们已经发布了MVC / Razor Pages UI. 这次2.9版中, 我们为Easy CRM应用程序发布了Angular UI.

Easy CRM应用程序中"订单详细"的截图.

查看Easy CRM文档学习如何下载并运行它.

ABP Suite模块代码生成

ABP Suite是一个工具,主要功能是用来为一个实体生成代码, 从数据库到UI层具有完整的CRUD功能.

ABP Suite的截图: 定义新实体的属性并且为你生成应用程序代码!

在本次发布之前它只工作于应用程序模板.现在,它支持为模块项目生成代码.利用代码生成的威力来创建可复用应用程序模块是很棒的一个做法.

除了这个主要功能,我们在这个版本中向ABP Suite添加了许多细微的改进.

注意:模块模板代码生成目前处于测试阶段.如果你发现任何bug,请告知我们.

Lepton主题

Lepton主题是我们为ABP商业版开发的一个商业主题.

  • 与Bootstrap 100%兼容 - 让你不写主题特定的HTML!
  • 提供不同类型的风格 - 看一下下图中的Material风格.
  • 提供不同类型的布局(侧/顶部菜单,流式/盒式布局...).
  • 轻量化,响应式和现代化.
  • 还有...它是可升级的,没有成本!你只需更新NuGet / NPM包来获得新的功能.

我们创建了它的专属网站:http://leptontheme.com/

在这里你可以查看所有的组件, 无需单独的应用程序.

这个网站目前正处于一个非常早期的阶段.我们将创建文档和和改进网站, 来为你的开发提供参考和探索主题的功能.

即将推出:文件管理模块

基于新的blob存储系统(上面介绍的),我们已经开始构建一个文件管理模块用来管理(浏览/上传/下载)你应用程序中分层文件系统并在用户与客户之间分享文件.

我们计划在ABP商业版v3.0中发行最初版本,并继续进行后续版本的改进.

关于下一个版本:3.0

我们在v2.8和v2.9中增加了许多新的功能.在下一个版本中,我们将完全专注于文档,性能优化和其它改进,如bug修复.

长期以来,我们每2周发布一个新功能版本.我们在v3.0以后继续这种方式.但是,v3.0是一个例外,开发周期大概为4周.v3.0的计划发布日期是2020年7月1日.

彩蛋:文章!

除了开发我们的产品,我们的团队都在不断地撰写各种主题的文章/教程.你可以看一下最新的文章:

posted @ 2020-06-05 14:58  WAKU  阅读(1267)  评论(0编辑  收藏  举报