使用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));
}
}