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="刪除"/>
}
上面的代碼寫在視圖中,表示如果具有用戶的刪除權(quán)限,就顯示刪除按鈕。這種方式比如在所有需要驗(yàn)證的地方,都按照這樣的格式去書寫。
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)重寫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í)也希望多多支持我們!
上一篇:C# 利用IRawPixels接口遍歷柵格數(shù)據(jù)
欄 目:C#教程
下一篇:c# 委托詳解
本文標(biāo)題:asp.net core mvc權(quán)限控制:在視圖中控制操作權(quán)限
本文地址:http://www.jygsgssxh.com/a1/C_jiaocheng/5928.html
您可能感興趣的文章
- 01-10asp.net中XML如何做增刪改查操作
 - 01-10實(shí)現(xiàn)ASP.NET無(wú)刷新下載并提示下載完成的開發(fā)思路
 - 01-10ASP.NET MVC命名空間時(shí)引起錯(cuò)誤的解決方法
 - 01-10C#網(wǎng)頁(yè)跳轉(zhuǎn)方法總結(jié)
 - 01-10ASP.NET總結(jié)C#中7種獲取當(dāng)前路徑的方法
 - 01-10適用于WebForm Mvc的Pager分頁(yè)組件C#實(shí)現(xiàn)
 - 01-10mvc C# JavaScript LigerUI oracle實(shí)現(xiàn)用戶的注冊(cè)、登陸驗(yàn)證、登陸
 - 01-10C# MVC模式下商品抽獎(jiǎng)功能實(shí)現(xiàn)
 - 01-10C#(asp.net)多線程用法示例(可用于同時(shí)處理多個(gè)任務(wù))
 - 01-10asp.net獲取系統(tǒng)當(dāng)前時(shí)間的方法詳解
 


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
 - 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
 - 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
 - 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
 - 5c語(yǔ)言計(jì)算三角形面積代碼
 - 6什么是 WSH(腳本宿主)的詳細(xì)解釋
 - 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
 - 8正則表達(dá)式匹配各種特殊字符
 - 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
 - 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
 
本欄相關(guān)
- 01-10C#通過(guò)反射獲取當(dāng)前工程中所有窗體并
 - 01-10關(guān)于ASP網(wǎng)頁(yè)無(wú)法打開的解決方案
 - 01-10WinForm限制窗體不能移到屏幕外的方法
 - 01-10WinForm繪制圓角的方法
 - 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
 - 01-10WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新
 - 01-10C#停止線程的方法
 - 01-10C#實(shí)現(xiàn)清空回收站的方法
 - 01-10C#通過(guò)重寫Panel改變邊框顏色與寬度的
 - 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已
 
隨機(jī)閱讀
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
 - 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
 - 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
 - 01-10delphi制作wav文件的方法
 - 01-10C#中split用法實(shí)例總結(jié)
 - 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
 - 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
 - 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
 - 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
 - 04-02jquery與jsp,用jquery
 


