在asp.net mvc中将action方法参数传递给ActionFilterAttribute

问题描述 投票:0回答:3

我知道我可以使用filterContext 来获取它。但是,如果操作方法参数的命名不同,则这不是很灵活。这应该有效:

[HttpGet]
[NewAuthoriseAttribute(SomeId = id)]
public ActionResult Index(int id)
{
    ...

public class NewActionFilterAttribute : ActionFilterAttribute
{   
    public int SomeId { get; set; }
    ...

但它没有(它甚至无法编译)。有任何想法吗?

asp.net-mvc asp.net-mvc-3 asp.net-mvc-2
3个回答
86
投票

基于@Pankaj 的答案和@csetzkorn 的评论:

您将参数名称作为字符串传递,然后检查filterContext

public class NewAuthoriseAttribute : ActionFilterAttribute
{
    public string IdParamName { get; set; }

    public override void OnActionExecuting(ActionExecutingContext filterContext)
    {
        if (filterContext.ActionParameters.ContainsKey(IdParamName))
        {
            var id = filterContext.ActionParameters[IdParamName] as Int32?;
        }
    }
}

[NewAuthorizeAttribute(IdParamName = "fooId")]
public ActionResult Index(int fooId)
{ ... }

2
投票

编辑

我假设您正在寻找参数名称的别名。这使您可以灵活地拥有参数名称的多个别名。

enter image description here

ActionParameterAlias.ParameterAlias 重载

enter image description here

如果是这样,您可以提供如下别名。

[ParameterAlias("Original_Parameter_Name", 
                 "New_Parameter_Name")]
[ParameterAlias("Original_Parameter_Name", 
                 "New_Parameter_Name1")]
[ParameterAlias("Original_Parameter_Name", 
                 "New_Parameter_Name2")]
[ParameterAlias("Original_Parameter_Name", 
                 "New_Parameter_Name3")]

公共 ActionResult ActionMethod(模型参数值) { 返回视图(参数值); }


原帖

试试这个。

属性

public class NewAuthoriseAttribute : ActionFilterAttribute
{
    public override void OnActionExecuting(ActionExecutingContext filterContext)
    {
        if (filterContext.ActionParameters.ContainsKey("id"))
        {
            var id = filterContext.ActionParameters["id"] as Int32?;
        }
    }
}

行动方法

确保将参数类型设置为可为空以避免运行时崩溃。

[NewAuthoriseAttribute]
public ActionResult Index(Int32? id)
{
}

0
投票

在新版本中,您只需要在类内部定义一个属性并在方法上方设置值即可。

public enum Roles
{
    Admin = 1,
    User
}

public class CustomAuthorizationAttribute : ActionFilterAttribute

{
    public Roles Role { get; set; }

    public override void OnActionExecuting(ActionExecutingContext context)
    {
        if (Role == Roles.Admin)
        {
            throw new UnauthorizedException(HttpStatusCode.Unauthorized, "AccessDenied", ResponseMessage.InvalidToken);
        }

        base.OnActionExecuting(context);
    }
}

  [CustomAuthorization(Role = Roles.Admin)]
    public IActionResult OnlyAdmin()
    {
        return Content("Hi Admin");
    }
© www.soinside.com 2019 - 2024. All rights reserved.