实体框架 - 验证

在本章中,我们将了解可用于 ADO.NET 实体框架的验证技术,这些技术可用于验证模型数据。实体框架提供了多种验证功能,这些功能可实现到用户界面以进行客户端验证,也可用于服务器端验证。

  • 在实体框架中,数据验证是捕获应用程序中不良数据的解决方案的一部分。

  • 默认情况下,实体框架使用多种数据验证方法在将所有数据写入数据库之前对其进行验证。

  • 但是,实体框架是在用户界面数据验证之后进行的。因此,在这种情况下,需要进行实体验证来处理 EF 抛出的任何异常并显示通用消息。

  • 有一些数据验证技术可以改进您的错误检查以及如何将错误消息传回给用户。

DbContext 有一个可覆盖的方法,称为 ValidateEntity。当您调用 SaveChanges 时,Entity Framework 将为其缓存中状态不是 Unchanged 的​​每个实体调用此方法。您可以直接在此处放置验证逻辑,如以下针对 Student 实体的示例所示。

public partial class UniContextEntities : DbContext {

   protected override System.Data.Entity.Validation
      .DbEntityValidationResult ValidateEntity(DbEntityEntry entityEntry, 
      System.Collections.Generic.IDictionary<object, object> items) {

         if (entityEntry.Entity is Student) {

            if (entityEntry.CurrentValues.GetValue<string>("FirstMidName") == "") {

               var list = new List<System.Data.Entity
                  .Validation.DbValidationError>();

               list.Add(new System.Data.Entity.Validation
                  .DbValidationError("FirstMidName", "FirstMidName is required"));

               return new System.Data.Entity.Validation
                  .DbEntityValidationResult(entityEntry, list);
            }
         }

         if (entityEntry.CurrentValues.GetValue<string>("LastName") == "") {

            var list = new List<System.Data.Entity
               .Validation.DbValidationError>();

            list.Add(new System.Data.Entity.Validation
               .DbValidationError("LastName", "LastName is required"));

            return new System.Data.Entity.Validation
               .DbEntityValidationResult(entityEntry, list);
         }

         return base.ValidateEntity(entityEntry, items);
   }
}

在上述 ValidateEntity 方法中,检查 Student 实体的 FirstMidName 和 LastName 属性,如果其中任何一个属性为空字符串,则返回错误消息。

我们来看一个简单的例子,其中创建了一个新的学生,但学生的 FirstMidName 为空字符串,如下面的代码所示。

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         Console.WriteLine("Adding new Student to the database");
         Console.WriteLine();

         try {

            context.Students.Add(new Student() {
               FirstMidName = "",
               LastName = "Upston"
            });

            context.SaveChanges();
         } catch (DbEntityValidationException dbValidationEx) {

            foreach (DbEntityValidationResult entityErr in 
               dbValidationEx.EntityValidationErrors) {

               foreach (DbValidationError error in entityErr.ValidationErrors) {
                  Console.WriteLine("Error: {0}",error.ErrorMessage);
               }
            }
         }

         Console.ReadKey();
      }
   }
}

当编译并执行上述示例时,您将在控制台窗口收到以下错误消息。

Adding new Student to the database  
Error: FirstMidName is required 

为了更好地理解,我们建议您逐步执行上述示例。