4

我想知道在保存模型之前验证模型的最佳方法是什么以及利弊。我在服务层和 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
        }
    }
}
4

1 回答 1

11

IValidatableObject通常用于对实体进行自我验证,即验证仅限于检查Person.

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

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

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

  • 它可以检查额外的业务规则,这些规则确实需要实体中不立即可用的信息Person(即在做出验证决策时从数据库中获取相关数据、使用其他 Web 服务等)。这里的一个例子是确定一个银行账户是否有可用资金,或者一天内是否进行了 10 次以上的提款。
  • 验证特定于状态的规则,例如,当插入或更新一个人时,可以应用不同的规则,或者如果这个人活着或死了,则可以应用不同的规则。自我验证可能无法使用此附加上下文。
  • 但是,服务/业务层检查仍然可以利用自我验证(例如person.Validate())(包括使用IValidatableObject)来防止重复规则。
于 2012-09-26T11:38:19.757 回答