asp.net core mvc權(quán)限控制:在視圖中控制操作權(quán)限
在asp.net core mvc中提供了權(quán)限驗(yàn)證框架,前面的文章中已經(jīng)介紹了如何進(jìn)行權(quán)限控制配置,權(quán)限配置好后,權(quán)限驗(yàn)證邏輯自動(dòng)就會(huì)執(zhí)行,但是在某些情況下,我們可能需要在代碼里或者視圖中通過(guò)手工方式判斷權(quán)限,我們現(xiàn)在就來(lái)介紹下具體的操作方法。
如果在控制器方法里想要判斷當(dāng)前用戶是否具有某個(gè)權(quán)限,可以直接使用HttpContext.User.HasClaim(string cliamtype,string cliamvalue)方法進(jìn)行判斷,該方法返回bool類型,返回true表示具有權(quán)限,否則不具有。
在視圖上我們往往需要控制某個(gè)按鈕或者超鏈接的權(quán)限,具有權(quán)限按鈕就顯示,否則不現(xiàn)實(shí)。那怎么樣才能達(dá)到這樣的效果?方法介紹如下:
1,在視圖中直接使用HttpContext.User.HasClaim(string cliamtype,string cliamvalue)判斷權(quán)限,然后控制按鈕是否顯示
@if(HttpContext.User.HasClaim("User","Delete")) { <input type='button' value="刪除"/> }
上面的代碼寫(xiě)在視圖中,表示如果具有用戶的刪除權(quán)限,就顯示刪除按鈕。這種方式比如在所有需要驗(yàn)證的地方,都按照這樣的格式去書(shū)寫(xiě)。
2,借助于asp.net core mvc的新特性taghelper可以簡(jiǎn)化第一種方式,至于什么是taghelper,以及它的作用這里就不再介紹,大家可以百度或谷歌搜索,這里直接介紹如何自定義權(quán)限驗(yàn)證的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>
上面的代碼是我們最終的效果,表示這個(gè)超鏈接是有在用戶具有claim(type=goods,value=edit)權(quán)限的時(shí)候才顯示,下面我們就來(lái)介紹如何實(shí)現(xiàn)這個(gè)taghelper。
1)首先我們定義一個(gè)類,派生自TagHelper類,并增加claim屬性定義,并增加ViewContext
class ClaimTagHelper:TagHelper { private const string ClaimAttributeName = "asp-claim"; public ClaimTagHelper() { } [HtmlAttributeName(ClaimAttributeName)] public string Claim { get; set; } }
2)我們的權(quán)限控制taghelper只運(yùn)用于button,a,input的元素上,所有我們需要加上HtmlTargetElement的特性,代碼如下:
[HtmlTargetElement("a", Attributes = ClaimAttributeName)] [HtmlTargetElement("button", Attributes = ClaimAttributeName)] [HtmlTargetElement("input", Attributes = ClaimAttributeName, TagStructure = TagStructure.WithoutEndTag)] public class ClaimTagHelper: TagHelper { ...... }
3)重寫(xiě)TagHelper的Process方法,在方法中使用HttpContext.User.HasClaim進(jìn)行權(quán)限判斷。在視圖中訪問(wèn)HttpContext必須借助于ViewContext對(duì)象,所以我們需要在當(dāng)前的TagHelper類中增加ViewContext引用,具體代碼如下:
public class ClaimTagHelper: TagHelper { ..... [HtmlAttributeNotBound] [ViewContext] public ViewContext ViewContext { get; set; } ..... }
基本條件都具備了,然后就是Process實(shí)現(xiàn),直接上代碼:
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])) { //無(wú)權(quán)限 output.SuppressOutput(); } } else { if (!ViewContext.HttpContext.User.HasClaim(m => m.Type == claimData[0] && m.Value == claimData[1])) { //無(wú)權(quán)限 output.SuppressOutput(); } } }
到這里就介紹完了,謝謝大家,如有不足之處,歡迎大家指導(dǎo)。
以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!
- ASP.NET?Core?MVC中的視圖(Views)
- ASP.NET Core MVC學(xué)習(xí)之視圖組件(View Component)
- ASP.NET Core MVC基礎(chǔ)學(xué)習(xí)之局部視圖(Partial Views)
- ASP.NET MVC中分部視圖的應(yīng)用方法
- 詳解使用asp.net mvc部分視圖渲染html
- ASP.NET MVC從視圖傳參到控制器的幾種形式
- ASP.NET MVC從控制器傳遞數(shù)據(jù)到視圖的四種方式詳解
- asp.net MVC 根據(jù)菜單樹(shù)類別不同動(dòng)態(tài)加載視圖的實(shí)現(xiàn)步驟
相關(guān)文章
深入分析C#中WinForm控件之Dock順序調(diào)整的詳解
本篇文章是對(duì)C#中WinForm控件之Dock順序調(diào)整進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05C#實(shí)現(xiàn)監(jiān)聽(tīng)串口數(shù)據(jù)的方法詳解
這篇文章主要為大家詳細(xì)介紹了C#實(shí)現(xiàn)監(jiān)聽(tīng)串口數(shù)據(jù)的相關(guān)方法,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,有需要的小伙伴可以參考一下2024-03-03C#創(chuàng)建磁性窗體的實(shí)現(xiàn)方法
經(jīng)常會(huì)遇到一種情況,即當(dāng)拖動(dòng)一個(gè)窗體(主窗體)時(shí),其他窗體(子窗體)隨著該窗體移動(dòng),當(dāng)拖動(dòng)子窗體時(shí),其他窗體將不跟隨移動(dòng),這就是磁性窗體,所以本文給大家介紹了C#創(chuàng)建磁性窗體的實(shí)現(xiàn)方法,需要的朋友可以參考下2024-04-04C#采用OpenXml實(shí)現(xiàn)給word文檔添加文字
這篇文章主要介紹了C#采用OpenXml實(shí)現(xiàn)給word文檔添加文字的方法,包括了用法的實(shí)例分析,是非常實(shí)用的技巧,需要的朋友可以參考下2014-09-09C#使用InstallerProjects打包桌面應(yīng)用程序的完整步驟
這篇文章主要給大家介紹了關(guān)于C#使用InstallerProjects打包桌面應(yīng)用程序的完整步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用C#具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07