0

我有以下 HTML:

<input type="image" src="/Images/actions/Delete.gif" alt="Delete" title="Delete" name="action" value="Delete"/>

在我的控制器中,我有以下自定义属性

[AttributeUsage(AttributeTargets.Method, AllowMultiple = false, Inherited = true)]
public class MultiButtonAttribute : ActionNameSelectorAttribute
{
    public string MatchFormKey { get; set; }
    public string MatchFormValue { get; set; }
    public override bool IsValidName(ControllerContext controllerContext, string actionName, MethodInfo methodInfo)
    {
        return controllerContext.HttpContext.Request[MatchFormKey] != null &&
            controllerContext.HttpContext.Request[MatchFormKey] == MatchFormValue;
    }
}

单击删除时应调用以下操作方法

    [HttpPost]
    [MultiButton(MatchFormKey = "action", MatchFormValue = "Delete")]
    public ActionResult Delete(MessageModel model)
    {
        return Content("Delete clicked");
    }

这与 Chrome 完美配合,但是当在 Firefox 中单击提交按钮时,我的操作方法 Delete() 不会被调用。

任何想法我做错了什么?

4

2 回答 2

1

根据 HTML 规范,<input name="action" type="image">单击时会发送名为的表单参数action.xaction.y但不会发送名为的表单参数action。Firefox 遵循规范,而 Chrome 没有。

但是,您的服务器端代码似乎明确检查action,这就是它在 Firefox 中不起作用的原因。

于 2013-06-14T17:35:23.953 回答
0

一些浏览器以不同的方式发送值。因此,您必须更深入地挖掘 RouteData,而不是使用普通请求,您将在其中找到所有值,包括来自 Firefox 的值。这是您的自定义属性的修改版本,适用于 Chrome、Firefox 和 IE。

[AttributeUsage(AttributeTargets.Method, AllowMultiple = false, Inherited = true)]
public class MultiButtonAttribute : ActionNameSelectorAttribute
{
    public string MatchFormKey { get; set; }  
    public string MatchFormValue { get; set; } 
    public override bool IsValidName(ControllerContext controllerContext, string actionName, MethodInfo methodInfo)
    {
        if (controllerContext.HttpContext.Request.RequestContext.RouteData.Values[MatchFormKey] != null)
        {
            return (string)controllerContext.HttpContext.Request.RequestContext.RouteData.Values[MatchFormKey] == MatchFormValue;
        }
        return false;
    }
}
于 2013-06-14T08:43:17.787 回答