ASP.Net MVC验证

验证是ASP.NET MVC应用程序中的一个重要方面。 它用于检查用户输入是否有效。 ASP.NET MVC提供了一组易于使用的验证,同时也是检查错误并在必要时向用户显示消息的强大方法。

DRY

DRY代表(Don’t Repeat Yourself )不要重复自己,是ASP.NET MVC的核心设计原则之一。从开发的角度来看,鼓励只在一个地方指定功能或行为,然后在整个应用程序中使用它。
这样可以减少编写的代码量,使代码编写起来更容易,更容易维护。

为模型添加验证

下面来看看,如何为上一章项目添加员工时验证的一个简单例子。 在这个例子中,我们将数据注释添加到模型类,它提供了一些内置的验证属性集,可以直接在应用程序中应用到任何模型类或属性,例如:RequiredStringLengthRegularExpressionRange验证属性。

它还包含格式化属性,如DataType帮助格式化,不提供任何验证。 验证属性指定要对其应用的模型属性强制执行的行为。

RequiredMinimumLength属性指示属性必须具有值; 但是没有任何东西阻止用户输入空白格来满足这个验证。RegularExpression属性用于限制可输入的字符。

可以通过添加不同的注释属性来更新 Employee 类,如以下代码所示 -



还需要对数据库设置限制。 但是,SQL Server对象资源管理器中的数据库显示name属性被设置为NVARCHAR(MAX),如以下截图所示 -

现在我们还需要对数据库设置限制。 但是,SQL Server对象资源管理器中的数据库显示name属性被设置为NVARCHAR(MAX),如以下屏幕截图所示 -

为了在数据库上设置这个限制,我们将使用迁移来更新模式。

工具 -> NuGet程序包管理器 -> 程序包管理器控制台 打开程序包管理器控制台窗口。

在软件包管理器控制台窗口中逐个输入以下命令。

Enable-Migrations
add-migration DataAnnotations
update-database

以下是在 程序包管理器控制台 窗口中执行这些命令后的日志。

Visual Studio也将打开从DbMIgration类派生的类,可以在其中看到更新Up方法中的模式约束的代码 -

namespace MVCSimpleApp.Migrations {
   using System;
   using System.Data.Entity.Migrations;

   public partial class DataAnnotations : DbMigration{
      public override void Up(){
         AlterColumn("dbo.Employees", "Name", c => c.String(maxLength: 60));
      }

      public override void Down(){
         AlterColumn("dbo.Employees", "Name", c => c.String());
      }
   }
}

name字段的最大长度为60,这是数据库中新的长度限制,如以下快照中所示 -

运行此应用程序并通过指定以下URL转到创建视图:http://localhost:63004/Employee/Create -

在这些字段中输入一些无效的数据,然后点击 创建 按钮,如下图所示 -

看到jQuery客户端验证检测到错误,并且还显示错误消息。


上一篇: ASP.Net MVC与SQL Server数据库操作 下一篇: ASP.Net MVC安全