asp.net core mvc許可權控制:許可權控制介紹

来源:http://www.cnblogs.com/dxp909/archive/2017/02/11/6388871.html
-Advertisement-
Play Games

在進行業務軟體開發的時候,都會涉及到許可權控制的問題,asp.net core mvc提供了相關特性。 在具體介紹使用方法前,我們需要先瞭解幾個概念: 1,claim:英文翻譯過來是聲明的意思,一個claim包含Type,Value兩項信息。我把claim理解成一個許可權的定義,比如Type=會員,Va ...


在進行業務軟體開發的時候,都會涉及到許可權控制的問題,asp.net core mvc提供了相關特性。

在具體介紹使用方法前,我們需要先瞭解幾個概念:

1,claim:英文翻譯過來是聲明的意思,一個claim包含Type,Value兩項信息。我把claim理解成一個許可權的定義,比如Type=會員,Value=刪除操作

2,Identity:表示用戶的身份信息,比如用戶名

3,Principal:我理解成認證票據,裡面包含identity,claim信息。

4,Policy:英文翻譯過來是政策的意思,我理解的是許可權驗證的一個規則,就是當前我需要如何驗證許可權,比如要執行當前操作,必須具有會員刪除操作的claim

5,角色:一組許可權的集合

6,用戶:一個使用系統的賬戶信息

 

在asp.net core mvc中配置許可權控制的方法:

1,引入Microsoft.AspNetCore.Identity.EntityFrameworkCore庫,這個庫中提供了用戶,角色,登錄等相關操作,並且可以進行功能擴展。

2,在startup.cs文件中註冊服務介面以及中間件

public void ConfigureServices(IServiceCollection services)

{

......

services.AddIdentity<TUser, TRole>();

.....

}

 public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory)

{

......

app.UseIdentity();

......

}

 

TUser:系統中自定義的用戶類

public class ApplicationUser: IdentityUser<int>

{

//系統中擴展的用戶參數

}

TRole:系統中自定義的角色類

public class ApplicationRole: IdentityRole<int>

{

//系統擴展的角色參數

}

3,在控制器或者控制器方法上增加AuthorizeAttribute特性,配置許可權控制

AuthorizeAttribute特性中包含了一個Policy配置,就是配置許可權驗證規則,實例如下:

[Authorize(Policy ="goods")]

 public class GoodsController : Controller

{}

 

但是這裡的goods只是規則的名稱,那這個規則又是如何設置的呢?在startup.cs的ConfigureServices中使用AddAuthorization擴展方法進行配置,實例如下:

 

  public void ConfigureServices(IServiceCollection services)

{

.....

services.AddAuthorization(config=>{

//

 config.AddPolicy("goods", builder => {
                builder.AddRequirements(new ClaimsAuthorizationRequirement("goods", new string[] { "module" }));
            });

});

.....

}

AddPolicy是增加規則方法,第一個參數表示規則的名稱,第二個參數是具體的規則列表,我們這裡只增加了一個許可權驗證的

規則ClaimsAuthorizationRequirement

 

ClaimsAuthorizationRequirement表示一個許可權規則的信息,構造方法包含兩個參數,第一個參數表示cliam的type值,第二個

參數是claim的value集合,它表示驗證當前用戶是否具有指定type,並且具有任意一個value中指定值的claim

 

經過以上配置後,如果當前用戶要訪問GoodsController控制器(不限制方法,如果AuthorizeAttribute是使用在方法上,那隻驗

證對應的方法,也可以多次使用),就必須具有Claim(type=goods , value=module)的許可權

 

到這裡,我們就完成了許可權控制的邏輯,以上內容只是個人理解,歡迎大家指正。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ls 列出文件和目錄-a:顯示所有文件和目錄,包括隱藏文件和目錄-l:顯示文件和目錄的完全屬性信息 cd 改變當前路徑(相對路徑與據對路徑) pwd 顯示當前的工作文目錄 mkdir 建立目錄-p:創建當前目錄(沒有父目錄的情況下)並創建父目錄。mkdir -p test1/test1-1 rmdi ...
  • 參考鏈接:http://www.cnblogs.com/shenbin/p/5680976.html web訪問介面報405錯誤,以前的jQuery訪問方式訪問介面沒有問題。 但是換成angularjs2.0之後調用介面就報405錯誤,ajax調用沒有問題。 查找資料之後找到解決方案: 原因是web ...
  • 解決辦法:在 webconfig 中 <appSettings> <add key="owin:AutomaticAppStartup" value="false" /> </appSettings> 添加 就可以了 參考鏈接:http://www.mamicode.com/info-detail- ...
  • 最近在做一個項目 ,需要我們做一個東西,我們姑且叫數據共用吧,我們公司叫A公司,對方公司叫B公司,就是A公司提供一個數據服務介面出去,B公司如果想拿我們數據的時候直接調用我們的服務介面就行了,我們同樣要獲取對方B方的數據,直接拿對方的數據,經過協商我們決定採用WCF服務的REST方式進行數據共用,數 ...
  • 上次看到博客介紹 Visual Studio 2017 RC,看到其中一個改進是啟動很快,這是一大進步,也是低配電腦的程式員的期望。不過還沒體驗,是驢是騾子拉出來看看,這不就開始下載。 1、打開官網:https://www.visualstudio.com/vs/visual-studio-2017 ...
  • 首先本次需求是在MVC5中進行的,通過收費的融雲服務來驗證手機號碼,而且本次的項目也是前後臺分離,所以添加了WEBAPI2,那麼先添加WEBAPI的介面 然後添加一個UserController介面文檔 ...
  • 前面的文章介紹瞭如何進行許可權控制,即訪問控制器或者方法的時候,要求當前用戶必須具備特定的許可權,但是如何在程式中進行許可權的分配呢?下麵就介紹下如何利用Microsoft.AspNetCore.Identity.EntityFrameworkCore框架進行許可權分配。 在介紹分配方法之前,我們必須理解權 ...
  • 在asp.net core mvc中提供了許可權驗證框架,前面的文章中已經介紹瞭如何進行許可權控制配置,許可權配置好後,許可權驗證邏輯自動就會執行,但是在某些情況下,我們可能需要在代碼里或者視圖中通過手工方式判斷許可權,我們現在就來介紹下具體的操作方法。 如果在控制器方法里想要判斷當前用戶是否具有某個許可權,可 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...