1.4 ABPZero - 启动模板 (ASP.NET Core)

1.4.1 简介

使用ABP和module-zero开始一个ASP.Net Core的新项目最简单的方式是使用启动模板。记住要勾选 Include module zero

在创建并且下载模板项目后:

  • 在VS2015+(推荐使用VS2015 Update3)里面打开你的项目

  • 选择 Web项目 作为启动项目。

  • Migrator.EF工具被用来添加/应用EF迁移。为了创建你的数据库,打开命令提示符并跳转到EF项目的根目录文件夹。然后运行 dotnet ef database update 命令。

  • 运行程序。默认:用户名是 admin 密码是 123qwe

在这个模板中,多租户模式 默认是开启的。如果你不需要开启,那么你可以在Core项目中禁用它。

1.4.2 社交账号登录

启动模板支持 Facebook,Twitter,Google+和Microsoft 登录。在 appsettings.json,你可以看到以下配置:

  1. "Facebook": {
  2. "IsEnabled": "false",
  3. "AppId": "",
  4. "AppSecret": ""
  5. },
  6. "Google": {
  7. "IsEnabled": "false",
  8. "ClientId": "",
  9. "ClientSecret": ""
  10. },
  11. "Twitter": {
  12. "IsEnabled": "false",
  13. "ConsumerKey": "",
  14. "ConsumerSecret": ""
  15. },
  16. "Microsoft": {
  17. "IsEnabled": "false",
  18. "ConsumerKey": "",
  19. "ConsumerSecret": ""
  20. }

在这里,你可以根据你的需求来决定开启那些配置。当然,你必须从这些相关的网站去获取它的Keys和Passwords。你可以从这些网站找到相关指南来了解怎么获取key。一旦你开启了某个社交网站登录并且输入真实的key,那么你可以在登录界面看到一个按钮。按照相似的方法,你可以实现其它的社交登录方式。

1.4.3 基于令牌的身份验证

对于浏览器启动模板使用基于令牌的身份验证。然而,如果你想使用移动应用程序访问Web Api或者应用服务(那些通过动态Web Api暴露的应用服务),那么你可能想要使用基于令牌的身份验证的机制。启动模板包括了不记名令牌验证基础设施。 在 .WebApi 项目中的 AccountController 包含了 Authenticate 的action,用来获取token。这样我们就可以在下一个请求中使用token。

在这里,我们使用 Postman (chrome扩展) 来展示 Requests 和 Reponses。

身份验证

发送一个带有 Context-Type=”application/x-www-form-urlencoded” 请求头的 POSThttp://localhost:62114/jwt-token/authenticate,如下所示:返回的JSON对象的 result 属性包含了这个token还有过期时间(默认是24小时并且改选项是可配置的)。我们可以保存并在下个请求中使用它。

启动模板(ASP.NET Core) - 图1

我们发送了表单值:tenancyName,usernameOrEmailAddress 以及 password。为了作为一个HOST用户认证,tenancyName不应该被发送。如上所示,

使用API

在取得token和身份认证后,我们可以使用该令牌调用任何需要授权的action。对于所有应用服务的远程调用都是有效的。例如:我们可以使用 User Service 来取得用户列表:

启动模板(ASP.NET Core) - 图2

模拟一个 带有Context-Type=”application/json” 请求头的POST 请求到 http://localhost:6334/api/services/app/tenant/GetTenants 并且 Authorization=”Bearer your- auth-token”。请求体是空的 {}。当然,请求体和响应体将会使用不同的APIs。

注意:为了表明这是一个AJAX请求,我们还需要添加 X-Requested-With 的请求头。因此,ASP.NET Core能够更好的处理请求,并且对成功和错误的情况返回合适的返回值。

在UI端的所有操作是有效的,那么对于Web Api操作也是有效的(因为在UI端使用的是相同的Web Api)并且可以很容易的被使用。

1.4.4 使用控制台迁移数据

启动模板包含了一个工具:Migrator.exe,使用这个工具可以轻松的迁移你的数据库。你可以运行这个应用来创建/迁移host和tenant的数据库。

启动模板(ASP.NET Core) - 图3

这个应用程序可以从它自己的 .config 文件里面取得host的连接字符串。在开始的地方是与web.confg相同的。确认配置文件里面的连接字符串是你想要连接的数据库。然后获取主机连接字符串。首先创建主机数据库,或者应用迁移如果该数据库已经存在。然后,取得租户的连接字符串并且对这些数据库运行迁移。如果没有专门的数据库那么它会跳过该租户,或者对于那些已迁移租户的数据库也会跳过(多个租户之间共享数据库)。

你可以在开发或者生产环境中使用这个工具对数据库迁移部署,而不是使用EF它自己的Migrate.exe(这需要一些必要的配置并且一次运行只能针对单个数据库)。

1.4.5 单元测试

启动模板中包含了测试的基础设施设置,并且有少数几个测试已经被集成到了.Test项目中。你可以检测它们,并可以很容易的写一些类似的测试。事实上,它们是集成测试而不是单元测试,因为它们会使用ABP基础设施测试你的代码(包括数据验证,身份权限认证,以及工作单元等等)。