原文:MVC数据验证使用小结

描述:MVC数据验证使用小结

内容:display,Required,stringLength,Remote,compare,RegularExpression

本人最近在公司用mvc做了一个修改密码的功能,使用的是mvc数据验证,现将使用心得分享给大家

首先,我们先分析一下,如果要实现密码修改功能,我们需要做哪些工作。先从页面说起吧,前台页面起码需要三个密码框吧,分别表示原始密码,新密码,重复新密码,最后再加一个按钮,这样一个页面的基本元素就构造完毕了

其次,我们需要对添加的数据进行验证,包括,原始密码正确性验证,新密码格式验证,重复输入的密码一致性验证

最后,我们把修改后的密码保存到数据库里就大功告成了(注:这里只是简单的实现了密码的修改功能)

所以,分析到这里,思路也就清晰了,下面就该实现了

一、设计思路

1、设计一个修改密码模型类

2、使用mvc创建一个该模型类的强类型视图

3、提交表单,将新密码保存到数据库

二、代码实现

1、我们先看一下设计的模型类的代码吧

     public class UserPwdEditModel {
[Display(Name = "旧密码")]
[Required(ErrorMessage = "请输入 {0}。")]
[Remote("Validate", "UserInfo", HttpMethod = "post", ErrorMessage = "旧密码错误")]
[Editable(true)]
public string OldPwd {
get;
set;
} [Display(Name = "新密码")]
[Required(ErrorMessage = "请输入 {0}。")]
[RegularExpression(@"^(([a-z]+)|([A-Z]+)).([0-9]+)", ErrorMessage = "密码只能包含英文、数字(必须以字母开头)")]
[StringLength(, MinimumLength = , ErrorMessage = "密码长度限制在6-18个字符")]
public string NewPwd {
get;
set;
} [Display(Name = "重复新密码")]
[Required(ErrorMessage = "请再次输入 新密码。")]
//[Remote("ValidateRepeatPwd", "UserInfo", HttpMethod = "post", AdditionalFields = "NewPwd", ErrorMessage = "两次密码不一致,请重新输入")]
[Compare("NewPwd", ErrorMessage = "两次密码不一致,请重新输入")]
public string RepeatPwd {
get;
set;
}
}

创建修改密码模型来

没错,我把页面上的基本元素做成了一个模型,这样可以很方便的使用mvc数据验证

2、下面我们创建强类型视图(创建过程省略...)

 @model GraduateMISX.ViewModels.UserInfo.UserPwdEditModel
@{
ViewBag.Title = "PasswordEdit";
Layout = "~/Views/Shared/_Layout.cshtml";
} @using (Html.BeginForm("PasswordEdit", "UserInfo", FormMethod.Get, new {
@id = "formOfBettersoft"
})) {
<div class="tree-add-group">
<div class="tree-add-title">
@Html.LabelFor(model => model.OldPwd)
</div>
<div class="tree-add-text">
@Html.PasswordFor(model => model.OldPwd)
@Html.ValidationMessageFor(model => model.OldPwd)
</div>
</div>
<div class="tree-add-group">
<div class="tree-add-title">
@Html.LabelFor(model => model.NewPwd)
</div>
<div class="tree-add-text">
@Html.PasswordFor(model => model.NewPwd)
@Html.ValidationMessageFor(model => model.NewPwd)
</div>
</div>
<div class="tree-add-group">
<div class="tree-add-title">
@Html.LabelFor(model => model.RepeatPwd)
</div>
<div class="tree-add-text">
@Html.PasswordFor(model => model.RepeatPwd)
@Html.ValidationMessageFor(model => model.RepeatPwd)
</div>
</div>
<div class="tree-add-group">
<input type="submit" value="保存" style="left: 200px" id="btnSubmit"/>
</div>
}

创建强类型视图

注:在使用Remote验证的时候应在Web.config文件下配置appsetting节

  <appSettings>
<add key="ClientValidationEnabled" value="true" />
<add key="UnobtrusiveJavaScriptEnabled" value="true" />
</appSettings>

配置web.config

三、运行截图

运行程序,点击提交按钮后将会看到模型验证已经生效

最新文章

  1. 判断是PC端还是移动端
  2. 字符串匹配(hash算法)
  3. JQuery学习之语法
  4. ADT中通过Android SDK Manager去安装x86的image时无法下载
  5. PSP记录表
  6. About Curah
  7. POJ2084 Game of Connections(数学,dp)
  8. C#模拟登录的htmlHelper类
  9. RxJava 与 Retrofit 结合的最佳实践
  10. Jplayer小样
  11. 【分享】bootstrap学习笔记
  12. [js高手之路]Vue2.0基于vue-cli+webpack Vuex用法详解
  13. Linux进程通信学习总结
  14. hive的高级查询(group by、 order by、 join 、 distribute by、sort by、 clusrer by、 union all等)
  15. vue组件创建的三种方式
  16. Python2还是Python3
  17. springIOC源码分析(BeanFactroy)
  18. nmon监控与 nmon analyser分析
  19. Hadoop:HDFS NameNode内存全景
  20. 【.Net】结合项目谈谈多线程

热门文章

  1. 1.0.2-学习Opencv与MFC混合编程之---为播放AVI视频添加滑动条
  2. Android来电监听
  3. FZOJ2110: Star
  4. 从零开始学C++之异常(一):C语言错误处理方法、C++异常处理方法(throw, try, catch)简介
  5. 使用JDBC对数据库实现批处理操作
  6. js传真实地址 C:\fakepath
  7. error: /usr/include/stdio.h: Permission denied 的一种情况分析
  8. hdu 5183(hash)
  9. 站在OC的基础上快速理解Swift的类与结构体
  10. UVa 11233 - Deli Deli