使用服务层或IValidatableObject

时间:2012-09-26 11:26:25

标签: entity-framework

我想知道在保存模型之前验证模型的最佳方法是什么以及优缺点。 我对服务层和IValidatableObject之间存在疑问。

服务层:

public class PersonService
{
    public void Insert(Person person)
    {
        if (!IsValid(person))
        {
            //something
        }
    }
}

IValidatableObject:

public class Person:IValidatableObject
{
    public IEnumerable<ValidationResult> Validate(ValidationContext validationContext)
    {
        if (!IsValid(this))
        {
            //something
        }
    }
}

1 个答案:

答案 0 :(得分:10)

IValidatableObject通常用于自我验证实体,即验证仅限于检查Person的属性。

自我验证(例如IValidatableObjectDataAnnotations)对于“初始”检查非常有用,例如在用户界面上,以确保用户填写了所有必填字段,并广泛地满足验证规则,如正则表达式匹配,字符串长度,日期范围等。

为了使您的Person实体与系统的其他部分分离,您将无法在自我验证中执行更高级的业务规则,这需要往返数据库,或使用服务调用外部系统。

相反,在服务/业务/经理层上进行的验证通常用作交易的一部分,例如,插入/更新/状态转换,这可以做更多涉及的验证,例如

  • 它可以检查其他业务规则,这些规则确实需要Person实体中不能立即获得的信息(即,在做出验证决策时从数据库中获取相关数据,使用其他Web服务等)。这里的一个例子是确定银行账户是否有任何可用资金,或者是否在一天内提取超过10个。
  • 验证特定于州的规则,例如在插入或更新人时可以应用不同的规则,或者如果该人活着或死亡,则可以应用不同的规则。自我验证可能无法使用此附加上下文。
  • 但是,服务/业务层检查仍然可以使用自我验证(例如person.Validate())(包括使用IValidatableObject)来防止重复规则。