转自:http://blog.sina.com.cn/s/blog_c21a857b0102wcus.html

常用的 DataAnnotations

1.Required :属性值必须非空或者不能只是空格,如果允许全空格可以[Required(AllowEmptyStrings = true)]

2.DisplayName :显示名 – 定义表单字段的提示名称

3.StringLength :字符串长度不能超过给定的最大长度,也可以指定最小长度:[StringLength(10, MinimumLength=2)]

4.Range :范围 – 数字的可输入范围[Range(10, 20)] ,属性值必须在指定的数值范围内,可以使用数值类型的最大最小值比如int.MinValue、int.MaxValue

5.Bind :绑定 – 列出在将请求参数绑定到模型的时候,包含和不包含的字段

6.ScaffoldColumn :支架列 - 在编辑表单的时候,需要隐藏起来的的字符    [ScaffoldColumn(true|false)]

7.Compare: 比较 - 与制定的字段值进行比较 具体见代码    [Compare("MyOtherProperty")]两个属性必须相同值,比如我们要求用户重复输入两次邮件地址时有用

8.RegularExpre ssion: 正则表达式匹配,字符串值必须匹配正则表达式,默认大小写敏感,可以使用(?i)修饰符关闭大小写敏感,比如[RegularExpre ssion("(?i)mypattern")]

9.DataType :在前端显示的文本框类型

10. Remote :服务端验证

11. [Editable(false)] //放在主键上显示不可修改

客户端验证

关于Model层数据验证的一些验证规则与相关验证属性标签小集

(1)常规验证(必填字段、字符串长度、正则表达式验证、范围验证<</span>数值、日期>等)

1. 必填字段

[Required]

public string FirstName { get; set; }

2. 字段长度 至多n位:

[StringLength(160)]

public string FirstName { get; set; }

要求至少n位:

[StringLength(160, MinimumLength=3)]

public string FirstName { get; set; }

3. 正则验证

[RegularExpre ssion(@”[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4}”)]

public string Email { get; set; }

4. 范围

[Range(35,44, UIHint("IntSlider"))] //左右托动块

public int Age { get; set; }

小数的情况:

[Range(typeof(decimal), “0.00”, “49.99”)]

public decimal Price { get; set; }

5. 服务端参与的验证

[Remote(“CheckUserName”, “Account”, ErrorMessage = "该姓名已存在")]

public string UserName { get; set; }

Remote异步请求验证,在[HttpGet]时获取指定Controller里面的指定方法验证, 次方法必须是[HttpGet]标记的,返回类型为Json类型的JavaScript对象。

然后在AccountController里指定一个CheckUserName方法:

public JsonResult CheckUserName(string username)

{

var result = Membership.FindUsersByName(username).Count == 0;

return Json(result, JsonRequestBehavior.AllowGet);

}

6. 比较

[RegularExpre ssion(@”[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4}”)]

public string Email { get; set; }

[Compare(“Email”)]

public string EmailConfirm { get; set; }

public string EmailConfirm { get; set; }

7. 自定义错误消息

正则:

[RegularExpre ssion(@”[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4}”,ErrorMessage=”Email doesn’t look like a valid email address.”)]

public string Email { get; set; }

具体示例如下:

[DisplayName("分组名称")]

[Required(ErrorMessage = "请输入账号")]

[StringLength(50, ErrorMessage = "请勿输入超过 50 个字")]

public string Name { get; set; }

[DisplayName("排序字段")]

[DataType(DataType.Password)]

[Required(ErrorMessage = "请输入排序字段")]

[RegularExpre ssion(@"^([\d]+)$", ErrorMessage = "请输入正确的Email.")]

public string Sequence { get; set; }

[DisplayName("备注")]

[DataTyle(DataType.MultilineText)]//数据显示为多文本

[Required(AllowEmptyStrings=true, ErrorMessage = "请输入中文姓名")]

[StringLength(50, ErrorMessage = "请勿输入超过 50 个字")]

public string Describe { get; set; }

[DisplayName("账号")]

[Required(ErrorMessage = "请输入账号")]

[StringLength(50, ErrorMessage = "请勿输入超过 50 个字")]

public string Account { get; set; }

[DisplayName("密码")]

[DataType(DataType.Password)]

[Required(ErrorMessage = "请输入密码")]

[StringLength(50, ErrorMessage = "请勿输入超过 50 个字")]

public string Password { get; set; }

[Required]

[DataType(DataType.Password)]

[Display(Name = "Current password")]

public string OldPassword { get; set; }(PMS已有

[Required]

[StringLength(100, ErrorMessage = "The {0} must be at least {2} characters long.", MinimumLength = 6)]

[DataType(DataType.Password)]

[Display(Name = "New password")]

public string NewPassword { get; set; }(PMS已有)

[Display(Name = "确认密码")]

[Compare("LogPassword", ErrorMessage = "密码必须一致")]

public virtual string LogPasswordConfirm { get; set; }(PMS已有)

[Display(Name = "Remember me?")]

public bool RememberMe { get; set; }(PMS已有)

[DisplayName("姓名")]

[Required(ErrorMessage = "请输入姓名")]

[StringLength(50, ErrorMessage = "请勿输入超过 50 个字")]

public string ChName { get; set; }  (PMS已有)

[DisplayName("昵称")]

[Required(ErrorMessage = "请输入昵称")]

[StringLength(50, ErrorMessage = "请勿输入超过 50 个字")]

public string NickName { get; set; }

[Display(Name = "出生日期")]

//[Range(typeof(DateTime), "2011-12-31", "1950-1-1", ErrorMessage = "{0}的范围是{1}到{2}")]

[DisplayFormat(DataFormatString = "{0:yyyy-MM-dd}", ApplyFormatInEditMode = true)]//显示格式

public virtual DateTime? Birthday { get; set; } //表示值可为Null

[DisplayName("年龄")]

[Range(1, int.MaxValue, ErrorMessage = "请输入大于等于1的数")]

public int Age { get; set; }

[DisplayName("Email")]

[Required(ErrorMessage = "请输入Email")]

[StringLength(255, ErrorMessage = "请勿输入超过 255 个字")]

[RegularExpre ssion(@"^([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4})$", ErrorMessage = "请输入正确的Email.")]

[DataType(DataType.EmailAddress)]

public string Email { get; set; } (PMS已有)

[DisplayName("电话号码")]

[RegularExpre ssion(@"^((0\d{2,5}-)|0\d2,50\d2,5)?\d{7,8}(-\d{3,4})?$", ErrorMessage = "电话格式有误。\n有效格式为:\n①本区7或8位号码[-3或4位分机号码,可选]\n②(3~5位区号)7或8位号码[-3或4位分机号码,可选]\n③3~5位区号-7或8位号码[-3或4位分机号码,可选]\n示例:023-12345678;(023)1234567-1234")]

public string Phone { get; set; }

[Display(Name = "身份证号码")]

[RegularExpre ssion(@"\d{17}[\d|X]|\d{15}", ErrorMessage = "{0}的格式不正确")]

public virtual string IdentityNo { get; set; }

[DisplayName("是否为管理员")]

public bool IsAdmin { get; set; }

[DisplayName("代表图示")]

[Required(ErrorMessage = "请选择代表图示")]

[Range(1, 3, ErrorMessage = "输入的值必须介于 1 到 3之间")]

public int AvatarIcon { get; set; }

[Display(Name = "逻辑删除标识")]

public virtual int IsLogicDelete { get; set; }

[DisplayName("验证码")]

public string AuthCode { get; set; }

[DisplayName("创建日期")]

public DateTime CreateTime { get; set; }

[DisplayName("网址")]

[RegularExpre ssion(@"http(s)?://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?", ErrorMessage = "请输入合法的网址!\n示例:

https://abc.a;http://www.abc.dd") ]

public string Httpaddress { get; set; }

普通文本:

[Required(ErrorMessage=”Your last name is required”)]

[StringLength(160, ErrorMessage=”Your last name is too long”)]

public string LastName { get; set; }

占位符:

[Required(ErrorMessage=”Your {0} is required.”)]

[StringLength(160, ErrorMessage=”{0} is too long.”)]

public string LastName { get; set; }

(2)数据库约束验证

如果不希望用户使用123456这样的过于简单的密码,可以使用check约束来实现:

ALTER TABLE staffinfoes WITH NOCHECK  ADD CONSTRAINT chk_logPassword

CHECK (logPassword NOT IN('123','123123','123456'))

其中,staffinfoes是表名称,chk_logPassword是约束名称,logPassword是列名称

DataAnnotations 验证的更多相关文章

  1. 使用System.ComponentModel.DataAnnotations验证字段数据正确性

    在.NET MVC 中,当页面提交model到Action的时候,自动填充ModelState.使用ModelState.IsValid进行方便快捷的数据验证,其验证也是调用命名空间System.Co ...

  2. Web Api 模型验证

    1.模型建立,在模型上类上添加System.ComponentModel.DataAnnotations验证属性 public class Product { public int Id { get; ...

  3. 应用程序框架实战十五:DDD分层架构之领域实体(验证篇)

    在应用程序框架实战十四:DDD分层架构之领域实体(基础篇)一文中,我介绍了领域实体的基础,包括标识.相等性比较.输出实体状态等.本文将介绍领域实体的一个核心内容——验证,它是应用程序健壮性的基石.为了 ...

  4. MVC Model数据验证

    概述 上节我们学习了Model的数据在界面之间的传递,但是很多时候,我们在数据传递的时候为了确保数据的有效性,不得不给Model的相关属性做基本的数据验证. 本节我们就学习如何使用 System.Co ...

  5. ASP.NET MVC3中Model验证

    原文:ASP.NET MVC3中Model验证 概述 上节我们学习了Model的数据在界面之间的传递,但是很多时候,我们在数据传递的时候为了确保数据的有效性,不得不给Model的相关属性做基本的数据验 ...

  6. DDD分层架构之领域实体(验证篇)

    DDD分层架构之领域实体(验证篇) 在应用程序框架实战十四:DDD分层架构之领域实体(基础篇)一文中,我介绍了领域实体的基础,包括标识.相等性比较.输出实体状态等.本文将介绍领域实体的一个核心内容—— ...

  7. WebApiClient的接口输入验证

    1. 文章目的 随着WebApiClient的不断完善,越来越多开发者选择WebApiClient替换原生的HttpClient,本文将介绍WebApiClient的接口参数输入有效性验证的新特性. ...

  8. C# MVC验证Model

    .NET Core MVC3 数据模型验证的使用 这里我先粘贴一个已经加了数据验证的实体类PeopleModel,然后一一介绍. using System; using System.Collecti ...

  9. [MVC4]Data Annotations Extensions:无法使用EmailAddress等验证特性的解决方法

    本文地址:http://www.cnblogs.com/egger/p/3404159.html  欢迎转载 ,请保留此链接๑•́ ₃•̀๑! 数据注解(Data Annotations) Web应用 ...

随机推荐

  1. OC 线程操作2 - NSThread

        方法1 :直接创建 alloc init - (void)createNSThread111{ /* 参数1: (nonnull id) 目标对象 self 参数2:(nonnull SEL) ...

  2. CentOS7下BIND配置主从服务器和缓存服务器

    系统环境:CentOS Linux release 7.4.1708 (Core)  3.10.0-693.el7.x86_64 软件版本:bind-chroot-9.9.4-51.el7_4.1.x ...

  3. KMP(2)

    KMP 算法(2):其细微之处 2017 年 05 月 13 日 • 技术 系列文章目录 KMP 算法(1):如何理解 KMP KMP 算法(2):其细微之处 本篇来谈一谈 KMP 的一些细微之处,直 ...

  4. 16进制string转成int

    http://blog.csdn.net/wl1524520/article/details/25706521

  5. 2018.07.12 atcoder Choosing Points(数学分析好题)

    传送门 一句话题意:给出n,d1,d2" role="presentation" style="position: relative;">n,d ...

  6. mysql报错排查总结

    mysql报错: [root@zabbix ~]# mysql ERROR 2002 (HY000): Can't connect to local MySQL server through sock ...

  7. aused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in class path resource [applicationContext.xml]: Invocation of init method fai

    org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'roleDaoImpl' ...

  8. SPSS—回归—曲线估计方程案例解析

    上一节介绍了线性回归,虽然线性回归能够满足大部分的数据分析的要求,但是,线性回归并不是对所有的问题都适用, 因为有时候自变量和因变量是通过一个已知或未知的非线性函数关系相联系的,如果通过函数转换,将关 ...

  9. 201709021工作日记--Volley源码详解(五)

    学习完了CacheDispatcher这个类,下面我们看下NetworkDispatcher这个类的具体细节,先上代码: /** * 提供一个线程执行网络调度的请求分发 * Provides a th ...

  10. 在mui中创建aJax来请求数据..并展示在页面上

    <!DOCTYPE html> <html> <head>     <meta charset="UTF-8">     <m ...