浅谈MVC数据验证

1、通常状况html

对于使用过MVC框架的人来讲,对MVC的数据验证不会陌生,好比,我有一个Model以下:前端

1     public class UserInfo
2     {
3         [Required(ErrorMessage = "UserName不可为空1111")]
4         public string UserName { get; set; }
5         public string Sex { get; set; }
6         public string Mobile { get; set; }
7         public string Address { get; set; }
8     }

前端:数据库

 1 @using (Html.BeginForm()) 
 2 {
 3     @Html.AntiForgeryToken()
 4     <div class="form-horizontal">
 5         <h4>UserInfo</h4>
 6         <hr />
 7         @Html.ValidationSummary(true, "", new { @class = "text-danger" })
 8         <div class="form-group">
 9             @Html.LabelFor(model => model.UserName, htmlAttributes: new { @class = "control-label col-md-2" })
10             <div class="col-md-10">
11                 @Html.EditorFor(model => model.UserName, new { htmlAttributes = new { @class = "form-control" } })
12                 @Html.ValidationMessageFor(model => model.UserName, "", new { @class = "text-danger" })
13             </div>
14         </div>
15         <div class="form-group">
16             @Html.LabelFor(model => model.Sex, htmlAttributes: new { @class = "control-label col-md-2" })
17             <div class="col-md-10">
18                 @Html.EditorFor(model => model.Sex, new { htmlAttributes = new { @class = "form-control" } })
19                 @Html.ValidationMessageFor(model => model.Sex, "", new { @class = "text-danger" })
20             </div>
21         </div>
22         <div class="form-group">
23             @Html.LabelFor(model => model.Mobile, htmlAttributes: new { @class = "control-label col-md-2" })
24             <div class="col-md-10">
25                 @Html.EditorFor(model => model.Mobile, new { htmlAttributes = new { @class = "form-control" } })
26                 @Html.ValidationMessageFor(model => model.Mobile, "", new { @class = "text-danger" })
27             </div>
28         </div>
29         <div class="form-group">
30             @Html.LabelFor(model => model.Address, htmlAttributes: new { @class = "control-label col-md-2" })
31             <div class="col-md-10">
32                 @Html.EditorFor(model => model.Address, new { htmlAttributes = new { @class = "form-control" } })
33                 @Html.ValidationMessageFor(model => model.Address, "", new { @class = "text-danger" })
34             </div>
35         </div>
36         <div class="form-group">
37             <div class="col-md-offset-2 col-md-10">
38                 <input type="submit" value="Create" class="btn btn-default" />
39             </div>
40         </div>
41     </div>
42 }

效果:框架

 

 

是的,MVC能够经过对一些属性添加必定的特性来对数据进行验证。这对你们来讲可能并不陌生。ui

若是仅仅是这样就完事了,那么也就没事么意思了。spa

2、经常使用状况code

在实际的开发中,咱们大都是经过EF,或者其余方式,使得数据库中的每个表或视图,都在代码中对应的一个类模型,对于经过数据库生成的模型,咱们不宜修改,退一步讲,即便咱们在这个类中对一些属性增长一些数据验证的特性,那么,数据库发生变化后,若是我再从新生成这些Model,咱们以前添加好的验证特性将没有了,那么,咱们如何解决这样的问题呢?orm

假如:htm

1     public class UserInfo
2     {    
3         public string UserName { get; set; }
4         public string Sex { get; set; }
5         public string Mobile { get; set; }
6         public string Address { get; set; }
7     }

UserInfo是经过数据库生成的一个模型,对于数据库生成的模型,咱们不宜修改。但那是,咱们又须要对这个模型中的某些属性进行数据验证,好比须要对UserName属性进行非空验证,那么咱们如何作呢?blog

你们一般会想到部分类,是的,咱们能够经过部分类来解决上述问题。

首先,咱们将模型中的类加上关键字 partial ,而后咱们再写一个这个模型的部分类。

1     public partial class UserInfo
2     {
3         [Required(ErrorMessage = "UserName不可为空1111")]
4         public string UserName { get; set; }
5     }

 可是,这样会提示咱们一个错误,就是类中存在重复的属性,是的,部分类中,属性是不能够重名的。那么,咱们该怎么办呢,MVC框架已经给了咱们解决方案了。

咱们能够这么写:

1     [MetadataType(typeof(MeteUserInfo))]
2     public partial class UserInfo
3     {
4         private class  MeteUserInfo
5         {
6             [Required(ErrorMessage = "UserName不可为空1111")]
7             public string UserName { get; set; }
8         }
9     }

这样,咱们上述的问题就迎刃而解了。

相关文章
相关标签/搜索