我有一个像这样的控制器:
[Authorize(Users="Admin")]
public class MyController : Controller
{
...
[AllowAnonymous]
public AllUsersAction()
{
}
}
Run Code Online (Sandbox Code Playgroud)
除了我确实想要授权AllUsersAction,只有所有授权用户都应该能够点击它,而不仅仅是管理员.
该怎么办?
编辑:我知道我可以授权整个控制器,并为所有应该可用的操作提供更多限制Admin.但我宁愿不把属性放在每一个动作上,而是一个.
问题可以更好地表达:如果目前不可能实现这种"极简主义",那么实现会是什么样的?
py3*_*str 12
使用Authorize属性,不带控制器的任何参数:
[Authorize]
public class MyController : Controller
{
...
public AllUsersAction()
{
}
[Authorize(Users="Admin")]
public ActionResult OnlyForAdmin()
{
}
}
Run Code Online (Sandbox Code Playgroud)
并为受限操作指定"授权"属性"角色/用户"属性.
遗憾的是,只有当action具有AllowAnonymous属性时,控制器上的Authorize属性才会绕过授权.幸运的是,如果action有自己的Authorize属性,你可以覆盖Authorize属性的OnAuthorization方法以跳过控制器授权属性:
public class CustomAuthorize : AuthorizeAttribute
{
public override void OnAuthorization(AuthorizationContext filterContext)
{
if(filterContext.ActionDescriptor.IsDefined(typeof(AuthorizeAttribute), true))
{
//skip authorization check if action has Authorize attribute
return;
}
base.OnAuthorization(filterContext);
}
}
Run Code Online (Sandbox Code Playgroud)
您可以在示例中使用此CustomAuthorize:
[CustomAuthorize(Users="Admin")]
public class MyController : Controller
{
...
[Authorize]
public AllUsersAction()
{
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6176 次 |
| 最近记录: |