詳解.Net Core 權(quán)限驗(yàn)證與授權(quán)(AuthorizeFilter、ActionFilterAttribute)
在.Net Core 中使用AuthorizeFilter或者ActionFilterAttribute來(lái)實(shí)現(xiàn)登錄權(quán)限驗(yàn)證和授權(quán)
一、AuthorizeFilter
新建授權(quán)類(lèi)AllowAnonymous繼承AuthorizeFilter,IAllowAnonymousFilter
public class AllowAnonymous : AuthorizeFilter, IAllowAnonymousFilter { }
新建攔截類(lèi)繼承AuthorizeFilter
public class LoginAuthorzation : AuthorizeFilter { }
在攔截類(lèi)里加入處理請(qǐng)求的方法
/// <summary> /// 請(qǐng)求驗(yàn)證,當(dāng)前驗(yàn)證部分不要拋出異常,ExceptionFilter不會(huì)處理 /// </summary> /// <param name="context">請(qǐng)求內(nèi)容信息</param> public override async Task OnAuthorizationAsync(AuthorizationFilterContext context) { if (IsHaveAllow(context.Filters)) { return; } //解析url // {/ Home / Index} var url = context.HttpContext.Request.Path.Value; if (string.IsNullOrWhiteSpace(url)) { return; } var list = url.Split("/"); if (list.Length<=0||url=="/") { return; } var controllerName = list[1].ToString().Trim(); var actionName = list[2].ToString().Trim(); //驗(yàn)證 var flag=PowerIsTrue.IsHavePower(controllerName, actionName); if (flag.Item1!=0) { context.Result = new RedirectResult("/Home/Index"); } } //判斷是否不需要權(quán)限 public static bool IsHaveAllow(IList<IFilterMetadata> filers) { for (int i = 0; i < filers.Count; i++) { if (filers[i] is IAllowAnonymousFilter) { return true; } } return false; }
新建一個(gè)業(yè)務(wù)邏輯判斷的類(lèi)
public static (int,string) IsHavePower(string controllerName,string actionName) { return (0,"通過(guò)"); }
在Startup注冊(cè)
services.AddMvc(options => { options.Filters.Add<LoginAuthorzation>(); // 添加身份驗(yàn)證過(guò)濾器 }
context.HttpContext.Request.Path.Value 獲取請(qǐng)求過(guò)來(lái)的url
二、ActionFilterAttribute
創(chuàng)建權(quán)限判斷類(lèi)繼承ActionFilterAttribute
public class ActionFilterAttributeLogin: ActionFilterAttribute { public override void OnActionExecuting(ActionExecutingContext filterContext) { var isDefined = false; var controllerActionDescriptor = filterContext.ActionDescriptor as ControllerActionDescriptor; if (controllerActionDescriptor != null) { isDefined = controllerActionDescriptor.MethodInfo.GetCustomAttributes(inherit: true) .Any(a => a.GetType().Equals(typeof(NoPermissionRequiredAttribute))); } if (isDefined) return; if (string.IsNullOrWhiteSpace(filterContext.HttpContext.Request.Query["LoginInfo"].ToString())) { var item = new ContentResult(); item.Content = "沒(méi)得權(quán)限"; filterContext.Result = new RedirectResult("/Account/Login"); } base.OnActionExecuting(filterContext); } public class NoPermissionRequiredAttribute : ActionFilterAttribute { public override void OnActionExecuting(ActionExecutingContext filterContext) { base.OnActionExecuting(filterContext); } } }
在Startup注冊(cè)
services.AddMvc(options => { options.Filters.Add<ActionFilterAttributeLogin>(); // 添加身份驗(yàn)證過(guò)濾器 -- 菜單操作權(quán)限 }
filterContext.ActionDescriptor as ControllerActionDescriptor 獲取請(qǐng)求進(jìn)來(lái)的控制器與方法
controllerActionDescriptor.MethodInfo.GetCustomAttributes(inherit: true )
.Any(a => a.GetType().Equals( typeof (NoPermissionRequiredAttribute))) 判斷請(qǐng)求的控制器和方法有沒(méi)有加上NoPermissionRequiredAttribute(不需要權(quán)限)
string.IsNullOrWhiteSpace(filterContext.HttpContext.Request.Query["LoginInfo"].ToString()) 判斷請(qǐng)求頭是否有標(biāo)識(shí)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- .net如何優(yōu)雅的使用EFCore實(shí)例詳解
- ASP.NET?Core?5.0中的Host.CreateDefaultBuilder執(zhí)行過(guò)程解析
- .Net Core中使用EFCore生成反向工程
- ASP.NET Core使用EF保存數(shù)據(jù)、級(jí)聯(lián)刪除和事務(wù)使用
- ASP.NET?Core使用EF查詢(xún)數(shù)據(jù)
- ASP.NET?Core使用EF創(chuàng)建模型(索引、備用鍵、繼承、支持字段)
- ASP.NET?Core使用EF?SQLite對(duì)數(shù)據(jù)庫(kù)增刪改查
- .net core實(shí)用技巧——將EF Core生成的SQL語(yǔ)句顯示在控制臺(tái)中
- 在.NET Core類(lèi)庫(kù)中使用EF Core遷移數(shù)據(jù)庫(kù)到SQL Server的方法
- .net連接oracle的3種實(shí)現(xiàn)方法
- C#利用ODP.net連接Oracle數(shù)據(jù)庫(kù)的操作方法
- .Net使用EF Core框架連接Oracle的方法
相關(guān)文章
ASP.NET?MVC5網(wǎng)站開(kāi)發(fā)用戶(hù)登錄、注銷(xiāo)(五)
這篇文章主要介紹了ASP.NET?MVC5?網(wǎng)站開(kāi)發(fā)中用戶(hù)登錄、注銷(xiāo)的實(shí)現(xiàn)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2015-09-09.NET使用DinkToPdf將HTML轉(zhuǎn)成PDF的示例代碼
這篇文章主要介紹了.NET使用DinkToPdf將HTML轉(zhuǎn)成PDF的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02.NET Core跨平臺(tái)串口通訊使用SerialPortStream基礎(chǔ)類(lèi)庫(kù)問(wèn)題解決
這篇文章介紹了.NET Core跨平臺(tái)串口通訊使用SerialPortStream基礎(chǔ)類(lèi)庫(kù)問(wèn)題解決,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-01-01使用visual studio自動(dòng)創(chuàng)建IIS虛擬目錄
使用visual studio自動(dòng)創(chuàng)建IIS虛擬目錄,需要的朋友可以參考一下2013-02-02微信公眾平臺(tái)開(kāi)發(fā)教程(八)Session處理問(wèn)題
本篇文章主要介紹了微信公眾平臺(tái)開(kāi)發(fā)教程(八)Session處理 ,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。2016-12-12ASP.NET三層架構(gòu)詳解 如何實(shí)現(xiàn)三層架構(gòu)
這篇文章主要為大家詳細(xì)介紹了ASP.NET三層架構(gòu),如何實(shí)現(xiàn)三層架構(gòu),本文為大家揭曉,感興趣的小伙伴們可以參考一下2016-05-05