asp.net-mvc – 在MVC命令,优先级和功能问题中授权属性
我没有完全掌握一些角色.使用[Authorize]属性 当你在控制器和动作上有[Authorize]属性时: >当两者都有角色时,此角色将具有访问权限 我明白了,那是合乎逻辑的.您需要先访问控制器才能运行操作. 我没有得到的是为什么这不起作用: [Authorize(Roles = "Algemeen Beheer,Admin,Coordinator,Secretariaat")] public class FacturatieGegevensController : Controller { [Authorize(Users = "Stefan.coordinator",Roles = "Algemeen Beheer,Admin")] public ActionResult Create(int instID) { return View(); } } 当我以具有角色协调员的用户Stefan.coordinator登录时,我可以访问控制器,但是我无法访问“创建操作”. 解决方法访问Create方法的条件是:
一旦完成了所有的AND / OR,这导致简单:
也就是说,在特定的AuthorizeAttribute中,用户和角色一起进行AND运算.在多个AuthorizeAttributes中,条件是AND. 想到这一点的最好方法是[Authorize]属性彼此不了解,因此每个属性都是独立执行的.首先是控制器级别的,然后是方法级别的.要访问该方法,您需要传递所有门. 编辑 – 有一个关于逻辑如何工作的问题,如上所述. 让: A = ROLE is "Algemeen Beheer" B = ROLE is "Admin" C = ROLE is "Coordinator" D = ROLE is "Secretariaat" E = USER is "Stefan.coordinator" 由于控制器级[授权]属性为(A || B || C || D),方法级[授权]属性为(E&(A || B)),多个[授权] ]属性由逻辑AND表示,逻辑最终为(A || B || C || D)&& (E&(A || B)),减少到E&& (A || B),要求用户命名为“Stefan.coordinator”并成为“Algemeen Beheer”或“Admin”角色.由于用户Stefan.coordinator不属于这两个角色,因此检查失败. 对你的特殊问题.. 如果要将自己的逻辑应用于[Authorize]属性检查,请继承AuthorizeAttribute并覆盖AuthorizeCore方法.这样你就可以说if(User ==“Stefan.coordinator”|| base.AuthorizeCore(…)){…}. (编辑:鄂州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- asp.net-mvc – 在ASP.NET MVC中实现工作单元的方法
- 加快ASP.NET中的构建时间
- asp.net – 在部分视图中强制使用没有Html.BeginForm / Aja
- asp.net-mvc – 如何在asp.net mvc中处理分页?
- 实体框架 – 使用EF和WebAPI,如何返回一个ViewModel并支持I
- 修改服务器配置 让asp.net文件后缀名随心所欲
- asp.net-mvc – ASP.NET MVC现在是“开源”.这是一件好事吗
- asp.net-mvc-3 – “区域”文件夹中的样式,脚本和图像
- asp.net – 是否可以根据用户角色隐藏/显示Kendo网格列?
- asp.net-mvc – 奇怪的错误w / NinjectValidatorFactory更新
- asp.net-mvc-3 – MVC 3使用RenderPage更改视图中
- 密码由6-12位数字或字母组成,密码哈希加密
- asp.net – 查询字符串参数使我的应用程序面临风
- 是否可以使用ASP.NET ScriptManager来使用Window
- asp.net-mvc-4 – WepApi控制器是否应该返回view
- ASP.NET学习CORE中使用Cookie身份认证方法
- asp.net – 为每个网站/应用程序创建单独的IIS应
- asp.net-mvc – Url.RouteUrl返回null
- asp.net – IE10中的LinkButtons不执行回发
- ASP.NET Webdeploy失败;项目中不存在AddSchedule