VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > 网络工程 > 网络工程师 >
  • 【.NET框架】—— ASP.NET MVC数据验证注解(三)

数据验证注解:通过在Models层,通过注解特性对模型属性,进行注解设置,来实现数据验证的功能。

主要命名空间:System.ComponentModel.DataAnnotations

1.1.ASP.NET MVC Required特性

Requierd特性:

n  设置必填属性,验证是否填写内容

n  服务端Model属性添加[Required]

n  前端提示错误信息

@Html.ValidationMessageFor()

示例代码:

①在Models层上引入System.ComponentModel.DataAnnotations命名空间,并为属性添加[Required]约束

复制代码
public class Student
    {
        [Required]
        //表示可以在前台展示姓名字段
        [DisplayName("姓名")]
        public string name { get; set; }
        [Required]
        [DisplayName("性别")]
        public string sex { get; set; }
        [Required]
        [DisplayName("年龄")]
        public int age { get; set; }
    }
复制代码

②前端页面加上对应的@Html.ValidationMessageFor(Model => Model.属性)注解,表示对对应的参数需要验证,会显示错误信息;

复制代码
<!--表示提交到本类对应的Controller控制器上-->
@using (Html.BeginForm())
{
<div>
    @Html.LabelFor(Model => Model.name)
    @Html.TextBoxFor(Model => Model.name)
    @Html.ValidationMessageFor(Model => Model.name)
</div>
<div>
    @Html.LabelFor(Model => Model.sex)
    @Html.TextBoxFor(Model => Model.sex)
    @Html.ValidationMessageFor(Model => Model.sex)
</div>
<div>
    @Html.LabelFor(Model => Model.age)
    @Html.TextBoxFor(Model => Model.age)
    @Html.ValidationMessageFor(Model => Model.age)
</div>
    <input type="submit" value="提交"/>
}
复制代码

③对应的提交Controller增加[HttpPost]提交方式,传入提交Model参数,显示到界面上;

[HttpPost]
public ActionResult Contact(Student stu)
{
      return View(stu);
}

如果前台页面数据为空,则会提示对应错误信息:

 

1.2.StringLength特性

StringLength特性验证输入字符串长度;

语法:

复制代码
public class Student
    {
        [Required]
        //表示可以在前台展示姓名字段
        [DisplayName("姓名")]
        [StringLength(20, MinimumLength = 5)] //设置最大输入长度为20个字符串,最小输入长度为5个字符串
        public string name { get; set; }
        [Required]
        [DisplayName("性别")]
        public string sex { get; set; }
        [Required]
        [DisplayName("年龄")]
        public int age { get; set; }
    }
复制代码

验证显示结果:

 

1.3.RegularExpression特性

RegularExpression表示正则表达式验证特性;

使用方式:[RegularExpression(表达式)]

[RegularExpression("[a-zA-Z]{5,20}")]
public string name { get; set; }

验证显示结果:

 

1.4.ASP.NET MVC Range特性

Range特性:主要用于验证数字类型的最大值和最小值;

使用方式:[Range(10,20)]

[Range(10, 20)] //限制年龄范围必须是10-20岁
[Range(typeof(decimal), "10.0", "20.0")] //限制年龄范围及类型
public int age { get; set; }

 

1.5.ASP.NET MVC Remote特性

Remote特性:主要是将属性数据发送到服务器,进行服务器验证后,返回信息

使用方式:[Remote(方法,控制器)]

Remote可以在任意控制器中加入判断的方法,在前端执行参数验证时每次调用该控制器上的方法进行验证,通过后返回视图结果:

复制代码
public class Student
{
      //Model类上面加上注解
      [Remote("CheakName", "Home")]
      [Required]
      [DisplayName("姓名")]
      public string name { get; set; }
}
复制代码

远端验证方法:

 

 

1.6.自定义错误信息ErrorMessage

ErrorMessage注解属性用于自定义错误信息显示,

用法:

[Required(ErrorMessage=“错误信息”)]

复制代码
public class Student
    {
        [Required(ErrorMessage="姓名不能为空!")]
        [DisplayName("姓名")]
        public string name { get; set; }
         [Required(ErrorMessage="性别不能为空!")]
        [DisplayName("性别")]
        public string sex { get; set; }
        [Required(ErrorMessage="年龄不能为空!")]
        [DisplayName("年龄")]
        public string age{get;set;}
    }
复制代码

 

1.7.Compare特性

Compare特性用于比较输入的内容是否相同

用法:

[Compare(“属性名称”)]

示例:

复制代码
@using (Html.BeginForm()) { 
<div>
    @Html.LabelFor(Model => Model.name)
    @Html.TextBoxFor(Model => Model.name)
    @Html.ValidationMessageFor(Model => Model.name)
</div>
  <div>
    @Html.LabelFor(Model => Model.name2)
    @Html.TextBoxFor(Model => Model.name2)
    @Html.ValidationMessageFor(Model => Model.name2)
</div>
    <input type="submit" value="保存" />
}

  public class Student
    {
        [Required(ErrorMessage="姓名不能为空!")]
        [DisplayName("姓名")]
        public string name { get; set; }
        [Compare("name")]
        [Required(ErrorMessage = "姓名2不能为空!")]
        [DisplayName("姓名")]
        public string name2 { get; set; }
    }
复制代码



原文:https://www.cnblogs.com/yif0118/p/13455472.html


相关教程