在asp.net mvc中使用数据批注验证唯一性
关于使用数据注释进行验证,我有各种各样的问题。我正在使用以下设置 asp.NETMVC2 实体框架4 数据注释 基本上,我试图让独特的验证工作,我有点困惑。我的模型如下:在asp.net mvc中使用数据批注验证唯一性,asp.net,validation,asp.net-mvc-2,data-annotations,Asp.net,Validation,Asp.net Mvc 2,Data Annotations,关于使用数据注释进行验证,我有各种各样的问题。我正在使用以下设置 asp.NETMVC2 实体框架4 数据注释 基本上,我试图让独特的验证工作,我有点困惑。我的模型如下: public class Buyer { public int Id { get; set; } [Required(ErrorMessage = "The email is required")] public string Email { get; set; } [Require
public class Buyer
{
public int Id { get; set; }
[Required(ErrorMessage = "The email is required")]
public string Email { get; set; }
[Required(ErrorMessage= "The name is required")]
public string Name { get; set; }
}
public class Seller
{
public int Id { get; set; }
[Required(ErrorMessage = "The email is required")]
public string Email { get; set; }
[Required(ErrorMessage= "The name is required")]
public string Name { get; set; }
}
我已经设置了一个独特的字段属性,如下所示
public class UniqueFieldAttribute : ValidationAttribute
{
public IUniqueValidator Validator { get; set; }
public int Id { get; set; }
public override bool IsValid(object value)
{
if (value == null)
{
return true;
}
return Validator.IsValid(Convert.ToString(value), Id);
}
}
然后,我创建了一个实现IUniqueValidator接口的验证器:
public class BuyerUniqueEmailValidator : IUniqueValidator
{
public bool IsValid(string value, int id)
{
TheDb db = new TheDb();
var existing = from Buyer b in db.Buyers
where b.Email.ToLower() == value.ToLower()
select b;
foreach (Buyer b in existing)
{
if (b.Id != id)
{
return false;
}
}
return true;
}
}
想法就在那里!然而,在执行时我遇到了问题。当我加上这个
[UniqueField(Validator=new BuyerUniqueEmailValidator(), Id=this.Id ErrorMessage= "This email is in use")]
该项目无法编译
基本上,我想知道的是,是否可以将类传递给validationAttribute以执行验证?还有,我怎样才能传递身份证
此外,是否要创建一个通用的、唯一的字段生成器,该生成器适用于所有具有电子邮件字段的模型,还是必须有BuyerEmailValidator、SellerEmailValidator等。我似乎无法正常工作
目前只担心服务器端
感谢您的代码实现无法看到任何对其自身事务不可见的记录,因此无法在多用户环境中可靠地工作。为什么不使用DB约束?我将在生产中添加DB约束。然而,这更多的是一个哲学问题。电子邮件应该是唯一的是一项业务规则,因此它应该在我的域模型中实现和测试。我理解你想要什么,但我也认为你希望它可靠地工作。您不能在模型级别执行此操作,而让它在100%的时间内工作。