IdentityServer4【QuickStart】之使用asp.net core Identity

使用asp.net core Identity

IdentityServer靈活的設計中有一部分是可以將你的用戶和他們的數據保存到數據庫中的。如果你以一個新的用戶數據庫開始,那么,asp.net core Identity是一個選擇。這個示例演示了如何在IdentityServer中使用asp.net core Ientity.

該示例假設你已經完成了前面的所有示例,這個示例將要用asp.net core Identity 模板創建一個新的項目,新項目會替換掉之前的IdentityServer。而其它的工程則沒有影響。

新建一個asp.net core Identity工程

第一步是在你的解決方案中添加一個asp.net core Identity的工程。考慮到大量的代碼都來源于asp.net core Identity,所以這里直接使用visual studio的一個模板。你最后得把舊的IdentityServer刪除。但是你還得配置一下。

那就從創建一個asp.net core web app開始把:

然后選擇MVC模板:

然后在更改身份驗證這里選擇“個人用戶賬戶”:

最后,當你選擇好之后,點擊確定。

修改宿主

別忘了把端口調整到5000.

這樣才能兼容之間創建好的客戶端和API。

添加IdentityServer的包

添加IdentityServer4.AspNetIdentity的nuget包。因為它依賴IdentityServer包,所以會自動的將IdentityServer4添加到項目中來。

Scopes和客戶端的配置

雖然是一個新的項目,我們仍然可以將舊項目中的代碼粘貼過來用一下。你現在將之前的IdentityServer中的Config類中的代碼粘貼到新項目中。

有一個改變的地方是需要禁用一下確認頁面的東西,因為我們現在還沒有配置關于確認頁面的任何東西。所以我們將RequireConsent設置為false:

new Client
{ClientId = "mvc",ClientName = "MVC Client",AllowedGrantTypes = GrantTypes.HybridAndClientCredentials,RequireConsent = false,ClientSecrets ={new Secret("secret".Sha256())},RedirectUris           = { "http://localhost:5002/signin-oidc" },PostLogoutRedirectUris = { "http://localhost:5002/signout-callback-oidc" },AllowedScopes ={IdentityServerConstants.StandardScopes.OpenId,IdentityServerConstants.StandardScopes.Profile,"api1"},AllowOfflineAccess = true
}

配置IdentityServer

還是和之前一樣,需要在ConfigureServices和Configure這兩個Startup中的方法中進行配置。

ConfigureServices

下面的代碼顯示了工程創建的時候生成的一些樣本代碼和底部添加的關于IdentityServer的代碼。在之前的示例中,AddTestUsers擴展方法用來將用戶注冊到DI中,但是這會兒我們用AddAspNetIdentity取代了。這個方法需要一個泛型的類型參數,這個類型參數的類型是你asp.net Identity User的類型。

public void ConfigureServices(IServiceCollection services)
{services.AddDbContext<ApplicationDbContext>(options =>options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));services.AddIdentity<ApplicationUser, IdentityRole>().AddEntityFrameworkStores<ApplicationDbContext>().AddDefaultTokenProviders();// Add application services.services.AddTransient<IEmailSender, EmailSender>();services.AddMvc();// configure identity server with in-memory stores, keys, clients and scopes
    services.AddIdentityServer().AddDeveloperSigningCredential().AddInMemoryPersistedGrants().AddInMemoryIdentityResources(Config.GetIdentityResources()).AddInMemoryApiResources(Config.GetApiResources()).AddInMemoryClients(Config.GetClients()).AddAspNetIdentity<ApplicationUser>();
}

需要注意的是關于IdentityServer的邏輯應該寫到AddIdentity方法之后。因為其中有一些方法被重寫了。

Configure

這里展示了創建工程的時候生成的代碼,還有添加了UseIdentityServer。

public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{if (env.IsDevelopment()){app.UseDeveloperExceptionPage();app.UseBrowserLink();app.UseDatabaseErrorPage();}else{app.UseExceptionHandler("/Home/Error");}app.UseStaticFiles();// app.UseAuthentication(); // not needed, since UseIdentityServer adds the authentication middleware
    app.UseIdentityServer();app.UseMvc(routes =>{routes.MapRoute(name: "default",template: "{controller=Home}/{action=Index}/{id?}");});
}

創建數據庫

現在已經給出了一個新的項目,你需要創建數據庫。你可以通過項目目錄下的命令行工具來執行dotnet?ef?database?update?-c?ApplicationDbContext,像這樣:

但我一般都會在程序包管理控制臺上輸入update-database

創建一個用戶

接下來,你需要運行應用并將一個用戶創建到數據庫中。點擊注冊(Register)按鈕:

?

?然后在注冊頁面上注冊一個用戶:

現在,你已經擁有了一個用戶,你可以登陸了。

在MVC客戶端上面登陸

運行MVC客戶端應用,然后你可以點擊Secure這個鏈接來進行登陸:

你會被重定向到asp.net Identity的登陸頁面上,輸入你新創建的那個用戶的信息:

然后你會被跳轉到確認頁面上,然后又迅速的重定向回MVC客戶端(因為我們配置了RequireConsetn=false了。)。然后,關于你的user的一些claim回被列出來。

客戶端可以代表你的用戶來訪問api,通過點擊Call API using application identity:

下一步

先前的示例項目中有確認頁面、錯誤頁面和登出頁面,這些缺失的部分你可以直接復制粘貼過來用。一旦你完成了,那個舊的項目就沒用了。。然后你需要將RequireConsent改成true。

最后,放上源碼:直接點擊下載?sample code for this quickstart?吧。

?

轉載于:https://www.cnblogs.com/pangjianxin/p/9378686.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/249865.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/249865.shtml
英文地址,請注明出處:http://en.pswp.cn/news/249865.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

vue demo1

1.開發工具 試過sublime&#xff0c;現在轉戰vscode&#xff0c;覺得很順手&#xff0c;總之啥工具習慣就好。 vscode用著不錯的插件&#xff0c;推薦安裝。 2.項目目錄介紹 vue-cli生成的項目目錄有點多&#xff0c;初看有點懵&#xff0c;梳理一下會好很多。 ├── ind…

mysql日志介紹

1. 錯誤日志 錯誤日志記錄的事件&#xff1a; a. 服務器啟動關閉過程中的信息 b. 服務器運行過程中的錯誤信息 c. 事件調試器運行一個事件時間生的信息 d. 在從服務器上啟動從服務器進程時產生的信息 2. 查詢日志 查詢日志記錄查詢語句與啟動時間&#xff0c;建議不是在調試環境…

Mac OS X終端的常用操作命令(UNIX指令)

用了十多年windows&#xff0c;終于換了個高配Mac,俗話說 無論前端還是后端最終還是走向了linux&#xff0c;無論是換了多少臺PC最終都會走向Mac。不學習命令行用什么Mac? 干就完了~ pwd 顯示現在的文件路徑 &#xff08;print working directory&#xff09; ls 顯示…

索引( index )

索引在龐大的數據庫上最能體現出作用&#xff0c;所謂索引就是根據需求將指定的列提取出來做索引表&#xff0c;可以顯著提高在查找數據方面的速度。 在索引的前提下還可以指定索引值是否唯一&#xff0c;索引值是單列或是多列索引。 根據索引類型&#xff0c;索引分為&#xf…

dependencies 和 devDependencies 區別

當我們項目需要下載一個模塊的時候&#xff0c;我們安裝npm包&#xff08;在項目目錄下面npm install module_name&#xff09;的時候&#xff0c;很多時候我們會在后面加上–save-dev 或 –save。這兩個參數代表什么呢&#xff1f; 初識 相信很多人都會回答&#xff1a; np…

CentOS下防御或減輕DDoS攻擊方法(轉)

查看攻擊IP 首先使用以下代碼&#xff0c;找出攻擊者IP netstat -ntu | awk {print $5} | cut -d: -f1 | sort | uniq -c | sort -n 將會得出類似如下的結果&#xff1a; 1 114.226.9.132 1 174.129.237.157 1 58.60.118.142 1 Address 1 servers) 2 118.26.131.78 3 123.125.1…

iTerm2 快捷鍵

Ctrl a&#xff1a;將光標移動到命令行首 Ctrl e&#xff1a;將光標移動到命令行尾 Ctrl w&#xff1a;刪除光標前的一個單詞 Ctrl u&#xff1a;刪除所有內容 Ctrl y&#xff1a;粘貼上次刪除的內容 Ctrl r&#xff1a;搜索歷史命令刪除光標之前的單詞&#xff1a;ctrl …

vscode - 添加背景圖片

首先&#xff0c;CtrlShiftP安裝backround &#xff0c; 而后重啟vscode會有默認的背景圖片 修改背景圖&#xff0c;可自定義三張 具體請看gif圖 最開始時&#xff0c;發現png根本不是全透明&#xff0c;用ps處理了一下&#xff08;下列所有操作均字母組合&#xff09; 1.1 Ctr…

架構設計雜談004——架構師

什么是架構設師 架構師是&#xff1a;負責系統架構設計的人、團隊或組織 架構師主要干什么 ●架構師是技術領導&#xff0c;領導并負責架構設計&#xff0c;負責做決策 ●架構師可以是團隊或組織&#xff0c;這個時候通常會有首席架構師 ●架構師必須掌握足夠的技術知識 ●架構…

學習JS基本數據類型與對象的valueOf方法

https://blog.csdn.net/licheng11403080324/article/details/60128090 https://yq.aliyun.com/articles/399499 轉載于:https://www.cnblogs.com/smzd/p/9548530.html

security和oauth2.0的整合

security和oauth2.0的整合 之前已經介紹過security的相關的介紹,現在所需要做的就是security和oauth2.0的整合,在原有的基礎上我們加上一些相關的代碼;代碼實現如下: pom.xml: <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http:…

關于Vue.use()詳解

問題 相信很多人在用Vue使用別人的組件時&#xff0c;會用到 Vue.use() 。例如&#xff1a;Vue.use(VueRouter)、Vue.use(MintUI)。但是用 axios時&#xff0c;就不需要用 Vue.use(axios)&#xff0c;就能直接使用。那這是為什么吶&#xff1f; 答案 因為 axios 沒有 install。…

百度TTS的來由

#### https://home-assistant.io/components/tts.baidu/#### https://github.com/charleyzhu/HomeAssistant_Components#### 當前使用自定義組件 https://bbs.hassbian.com/thread-1152-1-1.html#### 2018-3-15添加百度云語音識別 - platform: baidu language: zh app_i…

eslint 禁用命令

/* eslint-disable */ ESLint 在校驗的時候就會跳過后面的代碼還可以在注釋后加入詳細規則&#xff0c;這樣就能避開指定的校驗規則了/* eslint-disable no-new */常用&#xff1a; rules: {"comma-dangle": ["error", "never"], //是否允許對象…

分布式工具的一次小升級?

前言 之前在做 秒殺架構實踐 時有提到對 distributed-redis-tool 的一次小升級&#xff0c;但是沒有細說。 其實主要原因是&#xff1a; 秒殺時我做壓測&#xff1a;由于集成了這個限流組件&#xff0c;并發又比較大&#xff0c;所以導致連接、斷開 Redis 非常頻繁。 最終導致獲…

淺談vue $mount()

Vue 的$mount()為手動掛載&#xff0c;在項目中可用于延時掛載&#xff08;例如在掛載之前要進行一些其他操作、判斷等&#xff09;&#xff0c;之后要手動掛載上。new Vue時&#xff0c;el和$mount并沒有本質上的不同。 具體見代碼&#xff1a; 順便附上vue渲染機制流程圖&a…

小三角

{border-color: transparent;border-right-color: #e5e5e5;border-width: 7px;margin-top: -7px;right: 100%;top: 20px;border: solid transparent;content: " ";height: 0;width: 0;position: absolute;pointer-events: none; }轉載于:https://www.cnblogs.com/smz…

Laravel日志查看器 -- log-viewer擴展

1.修改laravel配置文件. config\app.php log>daily 2.在項目目錄中composer命令安裝擴展&#xff1a;composer require arcanedev/log-viewer 3.安裝成功后&#xff0c;需要在config\app.php 的providers陣列中注冊服務 Arcanedev\LogViewer\LogViewerServiceProvider::clas…

論一個程序員的自我修養-從一張圖片說起

故事起源 本來今天想寫.NET Core實戰之CMS系統第十五篇文章的。哈&#xff0c;奈何今天在新生命人脈群里面看到石頭哥分享的一張圖片&#xff0c;然后大家就議論了起來&#xff0c;不過我看的很懵逼&#xff0c;這圖什么意思啊&#xff1f;當一個朋友講述了這個圖片背后的故事的…

vue實例屬性之el,template,render

一、el&#xff0c;template&#xff0c;render屬性優先性 當Vue選項對象中有render渲染函數時&#xff0c;Vue構造函數將直接使用渲染函數渲染DOM樹&#xff0c;當選項對象中沒有render渲染函數時&#xff0c;Vue構造函數首先通過將template模板編譯生成渲染函數&#xff0c;然…