
內容:本文帶大家使用IdentityServer4進行使用使用EntityFramework Core進行配置和操作數據
作者:zara(張子浩) 歡迎分享,但需在文章鮮明處留下原文地址。
前兩章內容呢,無論是Client定義還是Server端對象資源定義都是存儲與內存,當然這個問題也被博友問到,那么我們如何從數據庫中讀取呢,當然這個IdentityServre已經想好為我們進行處理了,那么只需要安裝 IdentityServer4.EntityFramework 就可以了。

一般來說都會使用EF做遷移,那么如果讓EF支持.NET Cli命令行呢,打開項目。

在 </project> 之前添加一下代碼,用於支持Cli命令行,再此之后你可以去項目根目錄通過cmd.exe 執行 doenet ef,如果沒有出現error,就ok了!如果出現問題大多是都是這個放錯位置了。
<ItemGroup>
<DotNetCliToolReference Include="Microsoft.EntityFrameworkCore.Tools.DotNet" Version="2.0.0" />
</ItemGroup>
鑒於EF的靈活性,我們本篇文章使用SqlServer數據庫,就現在我們創建一個數據庫,還有一些相關的表。
為IdentityServer4.EntityFramework.Storage中的實體維護SqlServer的最新SQL腳本。他們就在這里。(隨便創建一個數據庫,把那兩個表放進去執行就好)
下面我們要在Server進行配置了,需要在 Startup.cs 中的方法 ConfigureServices 進行修改,首先我們定義了一個常量 connectionString ,這你肯定知道,這是一個數據庫連接字符串,再往下定義了一個 migrationsAssembly ,它獲取了程序集的名稱,再通過 AddIdentityServer 以及 AddOperationalStore 方法對數據庫的相關遷移配置進行了賦值。
const string connectionString = @"Data Source=(LocalDb)\MSSQLLocalDB;database=IdentityServer4.Quickstart.EntityFramework-2.0.0;trusted_connection=yes;"; var migrationsAssembly = typeof(Startup).GetTypeInfo().Assembly.GetName().Name; // configure identity server with in-memory stores, keys, clients and scopes services.AddIdentityServer() .AddTestUsers(Config.GetUsers()) // this adds the config data from DB (clients, resources) .AddConfigurationStore(options => { options.ConfigureDbContext = b => b.UseSqlServer(connectionString, sql => sql.MigrationsAssembly(migrationsAssembly)); }) // this adds the operational data from DB (codes, tokens, consents) .AddOperationalStore(options => { options.ConfigureDbContext = b => b.UseSqlServer(connectionString, sql => sql.MigrationsAssembly(migrationsAssembly)); // this enables automatic token cleanup. this is optional. options.EnableTokenCleanup = true; });
再此期間你會引用 System.Reflection 以及 Microsoft.EntityFrameworkCore ,如上面所述,上面是硬編碼形式進行配置了,更確切的說這些關於數據庫的配置都是一個叫做 ConfigurationStoreOptions 的對象,你可以隨便修改它,EF兼容的的數據庫它都是可以的。因為IdentityServer4實現了EF可實現的接口。
它從哪里實現了呢?我們不難發現,在 IdentityServerEntityFrameworkBuilderExtensions 中的定義中有一個叫做 AddOperationalStore 的參數,它就是為了添加動態的存儲庫,定義如下。
public static IIdentityServerBuilder AddOperationalStore<TContext>(this IIdentityServerBuilder builder, Action<OperationalStoreOptions> storeOptionsAction = null)
where TContext : DbContext, IPersistedGrantDbContext;

可見它實現了DbContext,而大家都是.NET 程序員,所以我覺得你應該知道了怎么回事了,就現在,請確保你的連接字符串正確,我們要開始進行遷移了!執行以下命令.
dotnet ef migrations add InitialIdentityServerPersistedGrantDbMigration -c PersistedGrantDbContext -o Data/Migrations/IdentityServer/PersistedGrantDb
dotnet ef migrations add InitialIdentityServerConfigurationDbMigration -c ConfigurationDbContext -o Data/Migrations/IdentityServer/ConfigurationDb
如果沒有什么問題,那么結果一定如下所示,當然您的項目中一定要安裝 Microsoft.EntityFrameworkCore ,否則將會出現 ERROR:Microsoft.EntityFrameworkCore.Metadata.Internal.DirectConstructorBinding .

您現在應該在項目中看到一個 〜/Data/Migrations/IdentityServer 文件夾。 這包含新創建的遷移的代碼。現在我們已經添加了遷移,我們可以編寫代碼來從遷移中創建數據庫。 我們還將使用我們在之前的快速入門中定義的內存配置數據對數據庫進行種子處理。在Startup.cs中添加這個方法來幫助初始化數據庫:
private void InitializeDatabase(IApplicationBuilder app) { using (var serviceScope = app.ApplicationServices.GetService<IServiceScopeFactory>().CreateScope()) { serviceScope.ServiceProvider.GetRequiredService<PersistedGrantDbContext>().Database.Migrate(); var context = serviceScope.ServiceProvider.GetRequiredService<ConfigurationDbContext>(); context.Database.Migrate(); if (!context.Clients.Any()) { foreach (var client in Config.GetClients()) { context.Clients.Add(client.ToEntity()); } context.SaveChanges(); } if (!context.IdentityResources.Any()) { foreach (var resource in Config.GetIdentityResources()) { context.IdentityResources.Add(resource.ToEntity()); } context.SaveChanges(); } if (!context.ApiResources.Any()) { foreach (var resource in Config.GetApis()) { context.ApiResources.Add(resource.ToEntity()); } context.SaveChanges(); } } }
上面的代碼可能需要將這些命名空間添加到您的文件中:
using IdentityServer4.EntityFramework.DbContexts; using IdentityServer4.EntityFramework.Mappers;
然后我們可以從Configure方法中調用它:
public void Configure(IApplicationBuilder app) { InitializeDatabase(app); }
現在,如果運行IdentityServer項目,則應創建數據庫並使用快速入門配置數據進行種子設定。您應該能夠使用SQL Server Management Studio或Visual Studio來連接和檢查數據。

最后你可以根據這個Client表來配置你的Config.cs中的GetUsers這樣服務端的配置也就如此了,當然你可以自定義數據庫的字段來適應你的應用程序,那么當然沒更新一次你就可以通過EF的相關命令倆更新數據庫。那么所有的更新記錄就在 __EFMigrationsHistory 表中。
