【发布时间】:2014-06-08 14:47:12
【问题描述】:
我正在为我公司的网站设置用户权限,我们需要创建几个不同的角色和权限。我从here 发现了一些关于创建实际角色和组以及如何实现它们的很棒的信息。但是,这仍然需要将角色硬编码到授权标签中,有没有办法动态填充授权标签,这样我就可以在网站上有一个页面,我可以快速为不同的页面分配不同的权限,而无需必须返回代码并修改我创建的每个页面的权限集?
【问题讨论】:
标签: asp.net asp.net-mvc permissions
我正在为我公司的网站设置用户权限,我们需要创建几个不同的角色和权限。我从here 发现了一些关于创建实际角色和组以及如何实现它们的很棒的信息。但是,这仍然需要将角色硬编码到授权标签中,有没有办法动态填充授权标签,这样我就可以在网站上有一个页面,我可以快速为不同的页面分配不同的权限,而无需必须返回代码并修改我创建的每个页面的权限集?
【问题讨论】:
标签: asp.net asp.net-mvc permissions
实现以下自定义授权属性。
public class CustomAuthorizeAttribute : AuthorizeAttribute
{
public CustomAuthorizeAttribute (params string[] roleKeys)
{
var roles = new List<string>();
var allRoles = (NameValueCollection)ConfigurationManager.GetSection("CustomRoles");
foreach(var roleKey in roleKeys) {
roles.AddRange(allRoles[roleKey].Split(new []{','}));
}
Roles = string.Join(",", roles);
}
public override void OnAuthorization(AuthorizationContext filterContext)
{
base.OnAuthorization(filterContext);
if (filterContext.Result is HttpUnauthorizedResult)
{
filterContext.Result = new RedirectResult("~/Error/AcessDenied");
}
}
}
然后将以下内容添加到 web.config 中
<section name="CustomRoles" type="System.Configuration.NameValueFileSectionHandler,System, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
然后,作为一个例子
<CustomRoles>
<add key="UsersPagePermission" value="HR,Accounts,Developers" />
</CustomRoles>
在您的控制器或操作或全局过滤器中(无论您喜欢哪个 :))添加属性
例如
[CustomAuthorize("UsersPagePermission")]
public class UserController : Controller
这将允许您修改 web.config 而不是更改权限的代码。
【讨论】:
customRoles 去哪里了,哪些部分?请您澄清一下。我的网络出现错误。配置。也请您显示两个用法示例。