检查远程验证MVC的当前项ID

时间:2015-02-12 11:43:04

标签: c# asp.net-mvc validation

我有一个场景,我不想允许重复的数据库条目,为此我使用Remote Validation属性。 内部模型

  [Remote("DepartmentNameExists", "Department", "Department Name is already taken.")]
    public string Name { get; set; }

内部控制器

  public JsonResult DepartmentNameExists(string name)
    {
        var user = db.Departments.Where(x => x.Name == name.Trim());

        return !user.Any() ?
          Json(true, JsonRequestBehavior.AllowGet) :
          Json(string.Format("{0} is allready exists.", name),
              JsonRequestBehavior.AllowGet);


    }

它适用于创建视图,但是当转到编辑时出现一些问题,例如在编辑页面上提交单击它将再次验证名称并阻止页面提交,因为数据库中已有相同的条目(这是我目前的活跃项目本身)。我怎么解决这个问题? 注意:我无法从编辑页面中删除验证,因为用户可能会输入任何其他现有名称而不是当前名称。

1 个答案:

答案 0 :(得分:2)

您需要使用AdditionalFields RemoteAttribute并使用该表的Id(主键)。

[Remote("DepartmentNameExists", "Department", "Department Name is already taken.", AdditionalFields = "Id")]
public string Name { get; set; }

在控制器中,检查名称是否存在,但您当前正在编辑的名称除外。

public JsonResult DepartmentNameExists(string name, int id = 0)
{
    return db.Departments.Any(x => x.Name == name.Trim() && x.Id != id) 
              ? Json(string.Format("{0} already exists.", name), 
                                        JsonRequestBehavior.AllowGet)
              : Json(true, JsonRequestBehavior.AllowGet);
}