繁体   English   中英

ASP.NET MVC:基于参数值保护操作

[英]ASP.NET MVC: Securing actions based on parameter values

我正在构建一个系统,其中一些用户可以访问某些数据,而其他用户则不能。

如何保护我的应用程序,以便用户A可以访问

/Product/1/Edit但不是/Product/2/Edit

我当时在考虑使用动作过滤器。 这是正确的方法吗?

是的,自定义“授权”操作过滤器是执行此操作的好地方。 您可以按照以下步骤进行操作:

public class MyCustomAuthorizeAttribute : AuthorizeAttribute
{
    public override void OnAuthorization(AuthorizationContext filterContext)
    {
        base.OnAuthorization(filterContext);

        if (!(filterContext.Result is HttpUnauthorizedResult))
        {
            var currentUser = filterContext.HttpContext.User.Identity.Name;
            var currentAction = filterContext.RouteData.GetRequiredString("action");
            var id = filterContext.RouteData.Values["id"];
            if (!HasAccess(currentAction, currentUser, id))
            {
                HandleUnauthorizedRequest(filterContext);
            }
        }
    }

    private bool HasAccess(string currentAction, string currentUser, object id)
    {
        // TODO: decide whether this user is allowed to access this id on this action
        throw new NotImplementedException();
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM