MVC Model数据验证
Razor:
Razor生成一个表单
@using(html.formbeign())
{
}
Razor提示出model验证的错误信息
@Html.ValidationSummary()
使用特性简写 Model数据验证
验证必填:
[Required(ErrorMessage=”用户名必填啊”)]
验证是否相等:
[Compare(“password”,ErrorMessage=”两次密码不一致”)]
//这是model的后台写入
if (string.IsNullOrEmpty(uid.username))
{
ModelState.AddModelError(“username”, “用户名不能为空”);
}
if (string.IsNullOrEmpty(uid.upassword))
{
ModelState.AddModelError(“upassword”, “密码不能为空”);
}
if (uid.upassword != uid.rupassword)
{
ModelState.AddModelError("rupassword", "两次的密码不一致");
}
if (uid.username != null && uid.username.Length < 6)
{
ModelState.AddModelError("username", "用户名长度必须小于6位");
}
//这是 model的后台使用特性写入的model验证
using System.ComponentModel.DataAnnotations; //使用特性简写后台model数据验证
namespace MvcApplication2.Models
{
public class UserInfo
{
[Required(ErrorMessage=”请输入用户名”)]
[MinLength(6,ErrorMessage=”a用户名至少6位”)]
public string username { set; get; }
[Required(ErrorMessage = “请输入密码”)]
public string upassword{ set; get; }
[Compare("upassword", ErrorMessage = "两次密码不一致")]
public string rupassword { set; get; }
public int unmber { set; get; }
}
}
改写数据验证的提示
1:把提示的信息放到文本框后面
@Html.ValidationMessageFor(a=>a.username)
重写 ValidationAttribute
public override bool IsValid(object value){}—-是重写的方法
自定义验证
(1)验证年龄必须大于18,必须成年才能访问
(2)自定义验证实现入职日期必须小于当前的日期
客户端(前端)验证
客户端验证都是不安全的,前端可以被绕过,进行直接请求后台,所以需要后台的验证
???问题:前端不安全为什么还是需要他
(1)可以避免大多数的热,毕竟网上不懂技术的人很多
(2)可以避免服务器的压力,不用每次都是验证都在服务器进行
步骤如下:
A:第一步:——-需要引用JS,微软官方需要引入的JS是
Jquery.validate.unobtrusive.js —-微软在 Jquery.validate.js上封装了一些人内容
前端实现验证用户名长度至少是6位:
MinLength=”6”
public ActionResult Add(UserInfo uid)
{
if (string.IsNullOrEmpty(uid.username))
{
ModelState.AddModelError("username", "用户名不能为空");
}
if (string.IsNullOrEmpty(uid.upassword))
{
ModelState.AddModelError("upassword", "密码不能为空");
}
if (uid.upassword != uid.rupassword)
{
ModelState.AddModelError("rupassword", "两次的密码不一致");
}
if (uid.username != null && uid.username.Length < 6)
{
ModelState.AddModelError("username", "用户名长度必须小于6位");
}
if (ModelState.IsValid)//模型验证全部通过
{
添加代码
}
return View();
}