占位符

 {0}对应属性
 {1}对应minimum
 {2}对应maximum
 
[StringLength(15, MinimumLength = 6, ErrorMessage = "密码长度必须在{2}和{1}之间")]
 
先创建一个资源文件
 
为了实现这种验证效果
 
资源文件里可以这样写
 
然后新建一个类,这个类主要实现验证和其它一些额外的属性,这个类是部分类,有加partial关键字,写注解别忘了加
System.ComponentModel.DataAnnotations命名空间
 
[MetadataType(typeof(Login_UserMetaData))]
public partial class Login_User
{
//验证需要用到
public class Login_UserMetaData
{
[Display(Name="用户名")]
[Required(ErrorMessageResourceName="Required",ErrorMessageResourceType=typeof(Resource))]
public string UserName { get; set; }
[Display(Name="密码")]
[Required(ErrorMessageResourceName = "Required", ErrorMessageResourceType = typeof(Resource))]
public string Password { get; set; }
}
}

然后控制器大概就需要这样的代码,记得action方法传进来的参数类型是类名,如果用string username这种形式,ModelState.IsValid将无效

[HttpPost]
public ActionResult Login(Login_User loginUser)
{
if (!ModelState.IsValid)
{//验证不通过返回
return View();
}
Login_User user=userManager.Login(loginUser.UserName, loginUser.Password);
if (user == null)
{//用户密码错误!
ViewBag.error = "用户名或密码错误!";
return View();
}
Session["user"] = user;
return RedirectToAction("index", "home");
}
这样做了之后,就可以实现服务端验证了,但这样还不够,这里还需要使用客户端验证,这可以大大减轻服务器负担。
view中的代码如下:
@{
ViewBag.Title = "后台登陆";
}
@model Letter.Data.Model.Login_User
<script src="~/Scripts/jquery.validate.min.js"></script>
<script src="~/Scripts/jquery.validate.unobtrusive.min.js"></script>
@using(Html.BeginForm()){
<div>
<label for="username">用户名:</label>
@Html.TextBoxFor(u=>u.UserName) @Html.ValidationMessage("UserName")
</div>
<div>
<label for="password">密码:</label>
@Html.PasswordFor(u=>u.Password) @Html.ValidationMessage("Password")
</div>
<div>
<input type="submit" value="登录" />@ViewBag.error
</div>
}

web.config应该有如下配置才有效

附上一个比较完整的验证

using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.Linq;
using System.Web;
using System.ComponentModel.DataAnnotations; namespace RegisterValidation.Models
{ public partial class User
{
[Key]
public int ID { get; set; }
[Display(Name="姓名")]
[Required(ErrorMessageResourceName="Required",ErrorMessageResourceType=typeof(Resource))]
public string Name { get; set; } [Display(Name="生日")]
//[RegularExpression(@"^\d{4}(\-|\/|\.)\d{1,2}\1\d{1,2}$",ErrorMessageResourceName="Regular",ErrorMessageResourceType=typeof(Resource))]
[Required(ErrorMessageResourceName="Required",ErrorMessageResourceType=typeof(Resource))]
public DateTime? Birthday { get; set; } [Display(Name="年龄")]
[Range(,,ErrorMessageResourceName="Range",ErrorMessageResourceType=typeof(Resource))]
public int Age { get; set; } [Display(Name="用户名")]
[Required(ErrorMessageResourceName = "Required", ErrorMessageResourceType = typeof(Resource))]
public string Username { get; set; } [Display(Name="密码")]
[Required(ErrorMessageResourceName="Required",ErrorMessageResourceType=typeof(Resource))]
public string Password { get; set; } [Display(Name="邮箱")]
[Required(ErrorMessageResourceName="Required",ErrorMessageResourceType=typeof(Resource))]
[RegularExpression(@"^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$",ErrorMessageResourceName="Regular",ErrorMessageResourceType=typeof(Resource))]
public string Email { get; set; } }
public class UserDBContext : DbContext
{
public DbSet<User> Users { get; set; }
}
}

另一个部分user类,包含确认密码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.ComponentModel.DataAnnotations; namespace RegisterValidation.Models
{
public partial class User
{
[Display(Name="确认密码")]
[Required(ErrorMessageResourceName = "Required", ErrorMessageResourceType = typeof(Resource))]
[StringLength(,MinimumLength=,ErrorMessageResourceName="StringLength",ErrorMessageResourceType=typeof(Resource))]
[Compare("Password",ErrorMessageResourceName="Compare",ErrorMessageResourceType=typeof(Resource))]
public string PasswordConfirm { get; set; }
}
}

资源文件如下

效果如下

Model验证功能的更多相关文章

  1. ASP.NET MVC Model验证(五)

    ASP.NET MVC Model验证(五) 前言 上篇主要讲解ModelValidatorProvider 和ModelValidator两种类型的自定义实现, 然而在MVC框架中还给我们提供了其它 ...

  2. ASP.NET MVC Model验证(四)

    ASP.NET MVC Model验证(四) 前言 本篇主要讲解ModelValidatorProvider 和ModelValidator两种类型的自定义实现,前者是Model验证提供程序,而Mod ...

  3. [ASP.NET MVC 小牛之路]16 - Model 验证

    上一篇博文 [ASP.NET MVC 小牛之路]15 - Model Binding 中讲了MVC在Model Binding过程中如何根据用户提交HTTP请求数据创建Model对象.在实际的项目中, ...

  4. Spring MVC 使用拦截器优雅地实现权限验证功能

    在上一篇 SpringAOP 实现功能权限校验功能 中虽然用AOP通过抛异常,请求转发等勉强地实现了权限验证功能,但感觉不是那么完美,应该用拦截器来实现才是最佳的,因为拦截器就是用来拦截请求的,在请求 ...

  5. ThinkPHP表单令牌验证功能详细介绍

    注:TP版本为3.1.3 在ThinkPHP框架下,两次提交同一个表单,比如提交信息后在浏览器点击后退退回上次的页面,重新点击提交按钮,就会提示“表单令牌错误”的信息. ThinkPHP新版内置了表单 ...

  6. ThinkPHP 类似Yii的Gii生成Model的功能。

    ThinkPHP 类似Yii的Gii生成Model的功能.自动生成ThinkPhp 3.1 的基础模型.. #!/usr/bin/env php <?php /** * * THINKPHP 基 ...

  7. Model 验证

    [ASP.NET MVC 小牛之路]16 - Model 验证 上一篇博文 [ASP.NET MVC 小牛之路]15 - Model Binding 中讲了MVC在Model Binding过程中如何 ...

  8. 实例:SSH结合Easyui实现Datagrid的新增功能和Validatebox的验证功能

    在我前面一篇分页的基础上,新增了添加功能和添加过程中的Ajax与Validate的验证功能.其他的功能在后面的博客写来,如果对您有帮助,敬请关注. 先看一下实现的效果: (1)点击添加学生信息按键后跳 ...

  9. thinkPHP 表单自动验证功能

    昨天晚上我们老大叫我弄表单自动验证功能,愁了半天借鉴了好多官网的知识,才出来,诶,总之分享一下我自己的成果吧! thinkphp 在Model基类为我们定义了自动验证的函数和正则表达式,我们只需要在对 ...

随机推荐

  1. CYQ.Data 快速开发EasyUI

    EasyUI: 前端UI框架之一, 相对ExtJs来说,算是小了,这两天,抽空看了下EasyUI的相关知识,基本上可以和大伙分享一下: 官网: http://www.jeasyui.com/ 学习的话 ...

  2. Linux 部署ASP.NET SQLite 应用 的坎坷之旅 附demo及源码

    Linux 部署ASP.NET SQLite 应用 的坎坷之旅.文章底部 附示例代码. 有一台闲置的Linux VPS,尝试着部署一下.NET 程序,结果就踏上了坑之路,不过最后算是完美解决问题,遂记 ...

  3. 微软StockTrader应用程序

    这是一个采用 .NET Enterprise Application Server 技术的端到端示例应用程序.应用程序代码可以从 这里 下载. 代码中演示了WCF服务和移动开发,包括用Xamarin ...

  4. 仅此一文让你明白ASP.NET MVC 之Model的呈现(仅此一文系列三)

    本文目的 我们来看一个小例子,在一个ASP.NET MVC项目中创建一个控制器Home,只有一个Index: public class HomeController : Controller { pu ...

  5. 如何在Visual Studio 2012中发布Web应用程序时自动混淆Javascript

    同Java..NET实现的应用程序类似,Javascript编写的应用程序也面临一个同样的问题:源代码的保护.尽管对大多数Javascript应用公开源代码不算是很严重的问题,但是对于某些开发者来说, ...

  6. 让Chrome 接管邮件连接,收发邮件更方便了

    页面中除了传统的超链接外,还可以将邮箱地址写入<a>标签,意思不表自明,当然是用户点击后就会打开相应的邮件客户端向这个连接指向的邮件地址发邮件. <a href="mail ...

  7. Module-Zero之版本管理

    返回<Module Zero学习目录> 概要介绍 版本实体 版本管理者 概要介绍 绝大多数的SaaS(多租户)应用都有多个具有不同特征的版本(包).因此,他们可以给租户(即客户)提供不同的 ...

  8. 过年7天乐,学nodejs 也快乐

    自从上次接触nodejs 已经好长时间了,但是年底公司太忙了 ,没时间看, 上次文章在ubuntu上安装nodejs[开启实时web时代] http://www.cnblogs.com/qqlovin ...

  9. Mycat配置及使用详解.

    首先我们来看下什么是Mycat:MyCat:开源分布式数据库中间件, 这里定义的很简单, 就是分布式数据库的中间件. 其实Mycat 是可以时mysql进行集群的中间件, 我们可以对mysql来分库分 ...

  10. iOS-应用闪退总结

    一.之前上架的 App 在 iOS 9 会闪退问题(iOS系统版本更新,未配置新版本导致闪退问题) 最新更新:(2015.10.02) 开发环境: Delphi 10 Seattle OS X El ...