如何在ASP.NET MVC 5中检查客户端上是否已经存在用户



使用Visual Studio 2013.4(Visual Studio 2013 Update 4),我创建了一个带有个人用户帐户身份验证配置的常规ASP.NET MVC 5项目。Visual Studio已经为我搭建了所有用户注册和登录功能,并且运行良好。

如何在注册页面上实现以下规则的客户端验证:没有具有相同电子邮件的已注册用户

您可以使用RemoteAttribute通过服务器回调执行客户端验证。

1) 将以下方法添加到AccountController:

[AllowAnonymous]
public async Task<JsonResult> UserAlreadyExistsAsync(string email)
{
    var result = 
        await userManager.FindByNameAsync(email) ?? 
        await userManager.FindByEmailAsync(email);
    return Json(result == null, JsonRequestBehavior.AllowGet);
}

2) 将Remote属性添加到RegisterViewModel类的Email属性:

[Remote("UserAlreadyExistsAsync", "Account", ErrorMessage = "User with this Email already exists")]
public string Email { get; set; }

其中CCD_ 5是服务控制器的名称,而CCD_。

这帮了很多忙。在我的情况下,它是一个表,在那里更新也是可能的。在这种情况下,上述解决方案不起作用。所以我想分享我对这个案例的解决方案。

在下面的解决方案中,我添加了一个要传递给控制器的附加字段(模型的主键)。然后在控制器中,我检查是否提供了主键。如果是这样的话,我们知道,我们来自更新网站,因为这是我们在模型中已经有ID的唯一情况。最后一步是检查字符串和主键是否相同。如果它们都是,那没关系,因为我们没有更改字符串中的任何内容。如果只有字符串相同,但ID不相同,这意味着我们更改了字符串并将其更改为另一个现有项字符串,因此返回false。

型号:

    [Key]
    [Display(Name = "Idee ID")]
    public int intIdeaID { get; set; }
    [Required(ErrorMessage = "Dieses Feld muss ausgefüllt werden")]
    [Display(Name = "Idee")]
    [Remote("ideaExists", "TabIdea", HttpMethod = "POST", ErrorMessage = "Es wurde bereits eine Idee mit dieser Bezeichnung erstellt", AdditionalFields = "intIdeaID")]
    public string strIdea { get; set; }

控制器:

[HttpPost]
public JsonResult ideaExists(string strIdea, int? intIdeaID)
{
    if (intIdeaID != null)
    {
        if (db.tabIdea.Any(x => x.strIdea == strIdea))
        {
            tabIdea existingTabIdea = db.tabIdea.Single(x => x.strIdea == strIdea);
            if (existingTabIdea.intIdeaID != intIdeaID)
            {
                return Json(false);
            }
            else
            {
                return Json(true);
            }
        }
        else
        {
            return Json(true);
        }
    }
    else
    {
        return Json(!db.tabIdea.Any(x => x.strIdea == strIdea));
    }
}

相关内容

  • 没有找到相关文章

最新更新