asp.net core mvc許可權控制:在視圖中控制操作許可權

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

在asp.net core mvc中提供了許可權驗證框架,前面的文章中已經介紹瞭如何進行許可權控制配置,許可權配置好後,許可權驗證邏輯自動就會執行,但是在某些情況下,我們可能需要在代碼里或者視圖中通過手工方式判斷許可權,我們現在就來介紹下具體的操作方法。 如果在控制器方法里想要判斷當前用戶是否具有某個許可權,可 ...


在asp.net core mvc中提供了許可權驗證框架,前面的文章中已經介紹瞭如何進行許可權控制配置,許可權配置好後,許可權驗證邏輯自動就會執行,但是在某些情況下,我們可能需要在代碼里或者視圖中通過手工方式判斷許可權,我們現在就來介紹下具體的操作方法。

如果在控制器方法里想要判斷當前用戶是否具有某個許可權,可以直接使用HttpContext.User.HasClaim(string cliamtype,string cliamvalue)方法進行判斷,該方法返回bool類型,返回true表示具有許可權,否則不具有。

在視圖上我們往往需要控制某個按鈕或者超鏈接的許可權,具有許可權按鈕就顯示,否則不現實。那怎麼樣才能達到這樣的效果?方法介紹如下:

1,在視圖中直接使用HttpContext.User.HasClaim(string cliamtype,string cliamvalue)判斷許可權,然後控制按鈕是否顯示

@if(HttpContext.User.HasClaim("User","Delete"))

{

<input type='button' value="刪除"/>

}

上面的代碼寫在視圖中,表示如果具有用戶的刪除許可權,就顯示刪除按鈕。這種方式比如在所有需要驗證的地方,都按照這樣的格式去書寫。

2,藉助於asp.net core mvc的新特性taghelper可以簡化第一種方式,至於什麼是taghelper,以及它的作用這裡就不再介紹,大家可以百度或谷歌搜索,這裡直接介紹如何自定義許可權驗證的taghelper。

<a asp-claim="goods,edit" asp-action="addgoods" asp-route-id="@goods.Id" class="btn-icon " title="編輯"><i class="icon-common-edit icon-pencil"></i></a>

上面的代碼是我們最終的效果,表示這個超鏈接是有在用戶具有claim(type=goods,value=edit)許可權的時候才顯示,下麵我們就來介紹如何實現這個taghelper。

1)首先我們定義一個類,派生自TagHelper類,並增加claim屬性定義,並增加ViewContext

class ClaimTagHelper:TagHelper

{

private const string ClaimAttributeName = "asp-claim";
        public ClaimTagHelper()
        {
           
        }


        [HtmlAttributeName(ClaimAttributeName)]
        public string Claim { get; set; }

}

 

2)我們的許可權控制taghelper只運用於button,a,input的元素上,所有我們需要加上HtmlTargetElement的特性,代碼如下:

[HtmlTargetElement("a", Attributes = ClaimAttributeName)]
    [HtmlTargetElement("button", Attributes = ClaimAttributeName)]
    [HtmlTargetElement("input", Attributes = ClaimAttributeName, TagStructure = TagStructure.WithoutEndTag)]
    public class ClaimTagHelper: TagHelper

{

......

}

3)重寫TagHelper的Process方法,在方法中使用HttpContext.User.HasClaim進行許可權判斷。在視圖中訪問HttpContext必須藉助於ViewContext對象,所以我們需要在當前的TagHelper類中增加ViewContext引用,具體代碼如下:

public class ClaimTagHelper: TagHelper

{

.....

[HtmlAttributeNotBound]
        [ViewContext]
        public ViewContext ViewContext { get; set; }  

.....

}

基本條件都具備了,然後就是Process實現,直接上代碼:

public override void Process(TagHelperContext context, TagHelperOutput output)
        {
            if (string.IsNullOrEmpty(Claim))
            {
                return;
            }


            string[] claimData = Claim.Split(new char[] { '-' }, StringSplitOptions.RemoveEmptyEntries);


            if (claimData.Length == 1)
            {
                if (!ViewContext.HttpContext.User.HasClaim(m => m.Type == claimData[0]))
                {
                    //無許可權
                    output.SuppressOutput();
                }
            }
            else
            {
                if (!ViewContext.HttpContext.User.HasClaim(m => m.Type == claimData[0] && m.Value == claimData[1]))
                {
                    //無許可權
                    output.SuppressOutput();
                }
            }

}

 

到這裡就介紹完了,謝謝大家,如有不足之處,歡迎大家指導。


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

-Advertisement-
Play Games
更多相關文章
  • SID: echo $ORACLE_SID service_name: sqlplus / as sysdba; show parameter instance_name; show parameter service_names; show parameter service; select in ...
  • 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框架進行許可權分配。 在介紹分配方法之前,我們必須理解權 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...