欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > Asp.Mvc 2.0用戶服務(wù)器驗證實例講解(4)

Asp.Mvc 2.0用戶服務(wù)器驗證實例講解(4)

熱門標(biāo)簽:辦公用地圖標(biāo)注網(wǎng)點怎么操作 西寧電銷外呼系統(tǒng)公司 海東防封電銷卡 安陸市地圖標(biāo)注app 寧德防封版電銷卡 南昌自動外呼系統(tǒng)線路 聊城智能電銷機(jī)器人電話 云南外呼系統(tǒng)代理 上海市三維地圖標(biāo)注

這一節(jié)給大家講解下ASP.NET MVC 2.0的服務(wù)器端驗證的用法。大家知道,一個項目只用JS客戶端驗證是不安全的,用戶可以禁用JS來繞過客戶端驗證,所以必須有服務(wù)器端驗證。
關(guān)于服務(wù)器端驗證,主要調(diào)用System.ComponentModel.DataAnnotations命名空間里面的類庫。
咱們這次還是以注冊頁面為例來講解服務(wù)器端驗證,主要對注冊頁面完成以下驗證
1.用戶名不能為空
2.密碼不能為空,密碼長度不能小于5位數(shù),
3.密碼和確認(rèn)密碼輸入必須一樣
4.郵件格式必須正確
咱們先看下效果圖

MVC中對所有字段的驗證,實際上只需要在MODEL層設(shè)置驗證規(guī)則就可以。
1.用戶名驗證
對用戶名的驗證,只需要驗證用戶名不為空就可以了,使用Required屬性,把此屬性綁定到MODEL的用戶名字段上就可以了。

/// summary> 
  /// 用戶名 
  /// /summary> 
  [DisplayName("用戶名")] 
  [Required(ErrorMessage="用戶名不能為空!")] 
  public string UserName 
  { get; set; } 

Required里面的參數(shù)表示具體的提示信息,此時如果用戶名為空,就會在前臺ASPX頁面出現(xiàn)用戶名不能為空的提示。當(dāng)然要在前臺顯示錯誤的提示信息。使用%:Html.ValidationMessageFor(m=>m.UserName)%>標(biāo)記就可以在前臺顯示錯誤的提示信息

2.密碼驗證
密碼驗證包括密碼不能為空和密碼長度限制。
驗證密碼為空和驗證用戶名為空一樣,使用Required屬性。
驗證密碼的長度使用StringLength屬性。

/// summary> 
  /// 密碼 
  /// /summary> 
  [DisplayName("密碼")] 
  [Required(ErrorMessage="密碼不能為空")] 
  [StringLength(10, ErrorMessage = "密碼長度不能小于5位",MinimumLength=5)] 
  public string UserPwd 
  { 
   get; 
   set; 
  } 

StringLength的第一個參數(shù)表示密碼的最大長度,ErrorMessage表示不滿足條件的時候的錯誤提示信息。
MinimumLength表示輸入內(nèi)容的最小長度.
當(dāng)然,前臺必須有地方顯示錯誤信息,顯示錯誤信息我們使用如下
%:Html.ValidationMessageFor(m=>m.UserPwd)%>

3.驗證密碼和確認(rèn)密碼是否一致
要驗證密碼和確認(rèn)密碼是否一致,這個稍微有點復(fù)雜,需要我們自定義驗證規(guī)則。自定義驗證規(guī)則我們需要繼承ValidationAttribute類.然后實現(xiàn)它的isvaild方法。

/// summary> 
 /// 此自定義類用于驗證密碼和確認(rèn)密碼必須一致 
 /// /summary> 
 [AttributeUsage(AttributeTargets.Class, AllowMultiple = true, Inherited = true)] 
 public class PwdMatch :ValidationAttribute 
 { 
 
  private object _typeid = new object(); 
  public string PWD { get; set; }//密碼 
  public string ConfirmPwd { get; set; }//確認(rèn)密碼 
 
 
  public PwdMatch(string pwd, string confirmPwd) 
   : base() 
  { 
   PWD = pwd; 
   ConfirmPwd = confirmPwd; 
  } 
 
  /// summary> 
  /// 返回錯誤的提示信息 
  /// /summary> 
  /// param name="name">/param> 
  /// returns>/returns> 
  public override string FormatErrorMessage(string name) 
  { 
   return ErrorMessage; 
  } 
 
  /// summary> 
  /// 重寫TYPEID 
  /// /summary> 
  public override object TypeId 
  { 
   get 
   { 
    return _typeid; 
   } 
  } 
 
  /// summary> 
  /// 判斷是否想到 
  /// /summary> 
  /// param name="value">value的值實際上是MODEL提交的MODEL類/param> 
  /// returns>/returns> 
  public override bool IsValid(object value) 
  { 
   PropertyDescriptorCollection properties = TypeDescriptor.GetProperties(value); 
   object originalValue = properties.Find(PWD, true ).GetValue(value);//獲取密碼 
   object confirmValue = properties.Find(ConfirmPwd, true).GetValue(value);//獲取確認(rèn)密碼的值 
   return Object.Equals(originalValue, confirmValue); 
 
  } 
 } 

 
 PwdMatch屬性類創(chuàng)建后,可把它標(biāo)記在注冊MODEL的上面,然后提交注冊的時候,就會驗證了
 [PwdMatch("UserPwd","ConfirPwd", ErrorMessage ="密¨¹碼?與®?確¨¡¤認(rèn)¨?不?匹£¤配?")]
 public class RegisterModel
{
 
}

PwdMatch的第一個參數(shù)表上密碼,名稱與RegisterModel中的密碼屬性相同,第二個字段是確認(rèn)密碼,名稱與RegisterModel與的確認(rèn)密碼屬性相同,最后一個參數(shù)是錯誤提示信息。
當(dāng)然,也要在前臺顯示錯誤提示信息,使用%:Html.ValidationSummary(true,"用®?戶¡ì創(chuàng)ä¡ä建¡§失º¡ì敗㨹!")%>就可以在前臺顯示一個總的錯誤信息列表。

4.郵箱驗證
郵箱驗證主要是郵箱格式驗證,驗證格式是否滿足要求.驗證郵箱我們使用RegularExpressions屬性就可以。

/// summary> 
  /// 用戶郵箱 
  /// /summary> 
  [DisplayName("郵箱")] 
  //[DataType(DataType.EmailAddress)] 
  [RegularExpression(@"^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$", ErrorMessage = "電子郵件格式錯誤")] 
  public string Email 
  { 
   get; 
   set; 
  } 


第一個參數(shù)郵箱驗證的正則表達(dá)式,第二個參數(shù)是錯誤提示信息。
在ASPX頁面顯示錯誤信息用%:Html.ValidationMessageFor(m=>m.Email)%>
以上是對用戶注冊信息的驗證,當(dāng)然,我們在提交信息的時候,要判斷驗證是否通過,我們使用ModelState.IsValid來判斷驗證是否通過,TRUE表示通過,F(xiàn)ALSE表示未通過。
model代碼:

/// summary> 
 /// 注冊用戶MODEL 
 /// /summary> 
 [PwdMatch("UserPwd", "ConfirPwd", ErrorMessage = "密碼與確認(rèn)不匹配")] 
 public class RegisterModel 
 { 
  /// summary> 
  /// 用戶名 
  /// /summary> 
  [DisplayName("用戶名")] 
  [Required(ErrorMessage="用戶名不能為空!")] 
  public string UserName 
  { get; set; } 
 
  /// summary> 
  /// 密碼 
  /// /summary> 
  [DisplayName("密碼")] 
  [Required(ErrorMessage="密碼不能為空")] 
  [StringLength(10, ErrorMessage = "密碼長度不能小于5位",MinimumLength=5)] 
  public string UserPwd 
  { 
   get; 
   set; 
  } 
 
  [DisplayName("確認(rèn)密碼")] 
  [Required(ErrorMessage="確認(rèn)密碼不能為空!")] 
  [StringLength(10, ErrorMessage = "確認(rèn)密碼長度不能小于5位",MinimumLength=5)] 
  public string ConfirPwd 
  { 
   get; 
   set; 
  } 
  /// summary> 
  /// 用戶郵箱 
  /// /summary> 
  [DisplayName("郵箱")] 
  //[DataType(DataType.EmailAddress)] 
  [RegularExpression(@"^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$", ErrorMessage = "電子郵件格式錯誤")] 
  public string Email 
  { 
   get; 
   set; 
  } 
 
  
 } 
 
  
 /// summary> 
 /// 此自定義類用于驗證密碼和確認(rèn)密碼必須一致 
 /// /summary> 
 [AttributeUsage(AttributeTargets.Class, AllowMultiple = true, Inherited = true)] 
 public class PwdMatch :ValidationAttribute 
 { 
 
  private object _typeid = new object(); 
  public string PWD { get; set; }//密碼 
  public string ConfirmPwd { get; set; }//確認(rèn)密碼 
 
 
  public PwdMatch(string pwd, string confirmPwd) 
   : base() 
  { 
   PWD = pwd; 
   ConfirmPwd = confirmPwd; 
  } 
 
  /// summary> 
  /// 返回錯誤的提示信息 
  /// /summary> 
  /// param name="name">/param> 
  /// returns>/returns> 
  public override string FormatErrorMessage(string name) 
  { 
   return ErrorMessage; 
  } 
 
  /// summary> 
  /// 重寫TYPEID 
  /// /summary> 
  public override object TypeId 
  { 
   get 
   { 
    return _typeid; 
   } 
  } 
 
  /// summary> 
  /// 判斷是否想到 
  /// /summary> 
  /// param name="value">value的值實際上是MODEL提交的MODEL類/param> 
  /// returns>/returns> 
  public override bool IsValid(object value) 
  { 
   PropertyDescriptorCollection properties = TypeDescriptor.GetProperties(value); 
   object originalValue = properties.Find(PWD, true ).GetValue(value);//獲取密碼 
   object confirmValue = properties.Find(ConfirmPwd, true).GetValue(value);//獲取確認(rèn)密碼的值 
   return Object.Equals(originalValue, confirmValue); 
 
  } 
 } 

前臺頁面代碼

%@ Page Language="C#" Inherits="System.Web.Mvc.ViewPageMvcLogin.Models.RegisterModel>" %> 
 
!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
 
html xmlns="http://www.w3.org/1999/xhtml" > 
head runat="server"> 
 title>注冊頁面/title> 
 script type="text/javascript" src="../../Scripts/jquery-1.4.1-vsdoc.js">/script> 
 script type="text/javascript" src="../../Scripts/jquery.validate.js">/script> 
 script type="text/javascript"> 
//  $().ready(function () { 
//   $("#form1").validate( 
//  { 
//   rules: 
//   { 
//    UserName: 
//    { 
//     required: true 
//    }, 
//    UserPwd: 
//    { 
//     required: true, 
//     minlength: 6 
//    }, 
//    ConfirPwd: 
//    { 
//     required: true, 
//     minlength: 6, 
//     equalTo: "#UserPwd" 
 
//    }, 
//    Email: 
//    { 
//     email: true 
//    } 
 
//   }, 
//   messages: 
//   { 
//    UserName: 
//    { 
//     required: "span style='color:red'>用戶名不能為空! /span>" 
//    }, 
 
//    UserPwd: 
//    { 
//     required: "span style='color:red'>密碼不能為空!/span>", 
//     minlength: jQuery.format("span style='color:red'>密碼長度不能小于{0}個字符!/span>") 
//    }, 
//    ConfirPwd: 
//    { 
//     required: "span style='color:red'>確認(rèn)密碼不能為空!span>", 
//     minlength: jQuery.format("確認(rèn)密碼長度不能小于{0}個字符!"), 
//     equalTo: "span style='color:red'>兩次輸入密碼不一致!/span>" 
 
//    }, 
//    Email: 
//    { 
//     email: "span style='color:red'>郵箱輸入格式不正確!/span>" 
//    } 
//   }, 
//   onkeyup: false 
//  }); 
 
//  }); 
 /script> 
/head> 
body> 
 div> 
 br /> 
 
 p style="font-size:12px;color:red"> 
 
 %if (ViewData["msg"] != null) 
  {%> 
 %:ViewData["msg"]%> 
 %} %> 
 /p> 
 br /> 
 p> 
  %:Html.ValidationSummary(true,"用戶創(chuàng)建失敗!") %> 
 /p> 
 %Html.BeginForm("Register", "user", FormMethod.Post, new { name="form1",id="form1"}) ; %> 
 
 
  table> 
   tr> 
    td>%: Html.LabelFor(m => m.UserName) %>/td> 
    td> %: Html.TextBoxFor(m => m.UserName) %>/td> 
    td>%:Html.ValidationMessageFor(m=>m.UserName) %>/td> 
   /tr> 
 
    tr> 
    td> %: Html.LabelFor(m => m.UserPwd) %>/td> 
    td> %: Html.PasswordFor(m => m.UserPwd) %>/td> 
    td>%:Html.ValidationMessageFor(m=>m.UserPwd) %>/td> 
   /tr> 
 
    tr> 
    td> %: Html.LabelFor(m => m.ConfirPwd) %>/td> 
    td> %: Html.PasswordFor(m => m.ConfirPwd)%>/td> 
    td>%:Html.ValidationMessageFor(m=>m.ConfirPwd) %>/td> 
   /tr> 
 
    tr> 
    td> %: Html.LabelFor(m => m.Email) %>/td> 
    td> %: Html.TextBoxFor(m => m.Email) %>/td> 
    td>%:Html.ValidationMessageFor(m=>m.Email) %>/td> 
   /tr> 
 
    tr> 
    td> input type="submit" value="提交" />/td> 
    td>/td> 
    td>/td> 
   /tr> 
 
 
  /table> 
 
 
 
 %Html.EndForm(); %> 
  
 /div> 
/body> 
/html> 

controller代碼

/// summary> 
 /// 注冊提交 
 /// /summary> 
 /// param name="model">/param> 
 /// returns>/returns> 
 [HttpPost] 
 public ActionResult Register(Models.RegisterModel model) 
 { 
  if (ModelState.IsValid) 
  { 
   //驗證通過 
   bool result = false; 
   if (!new Models.SqlHelper().ExistUser(model)) 
   { 
    result = new Models.SqlHelper().AddUser(model); 
   } 
 
   if (result) 
   { 
    //添加成功轉(zhuǎn)向主頁 
    FormsService.SignIn(model.UserName, false); 
    return RedirectToAction("index"); 
   } 
   else 
   { 
    //返回注冊頁面 
    ViewData["msg"] = "添加用戶失敗"; 
    return View(model); 
   } 
 
  } 
  else 
  { 
   //驗證不通過 
   //返回注冊頁面 
   ViewData["msg"] = "添加用戶失敗"; 
   return View(model); 
  } 
 }

以上就是Asp.Mvc 2.0用戶服務(wù)器驗證實例的實現(xiàn)全過程,希望大家可以結(jié)合上一篇客戶端驗證進(jìn)行練習(xí),希望這篇文章可以更好地幫助大家掌握Asp.Mvc 2.0驗證功能。

您可能感興趣的文章:
  • asp.net之生成驗證碼的方法集錦(一)
  • 詳解ASP.NET七大身份驗證方式以及解決方案
  • ASP.NET中驗證控件的使用方法
  • ASP.NET MVC3網(wǎng)站創(chuàng)建與發(fā)布(1)
  • ASP.NET MVC3模板頁的使用(2)
  • ASP.NET MVC4之js css文件合并功能(3)
  • Asp.Mvc 2.0實現(xiàn)用戶注冊實例講解(1)
  • Asp.Mvc 2.0實現(xiàn)用戶登錄與注銷功能實例講解(2)
  • Asp.Mvc 2.0用戶客戶端驗證實例講解(3)
  • 創(chuàng)建第一個ASP.NET應(yīng)用程序(第1節(jié))
  • ASP.NET網(wǎng)站模板的實現(xiàn)(第2節(jié))
  • ASP.NET網(wǎng)站聊天室的設(shè)計與實現(xiàn)(第3節(jié))
  • ASP.NET實現(xiàn)用戶注冊和驗證功能(第4節(jié))
  • ASP.NET在線文本編輯控件的使用(第6節(jié))
  • ASP.NET實現(xiàn)數(shù)據(jù)的添加(第10節(jié))
  • ASP.NET用戶注冊實戰(zhàn)(第11節(jié))
  • Asp.Mvc 2.0用戶的編輯與刪除實例講解(5)
  • ASP.NET對大文件上傳的解決方案
  • Asp.Net上傳圖片同時生成高清晰縮略圖
  • ASP.NET MVC5添加驗證(4)

標(biāo)簽:南寧 青海 贛州 崇左 汕尾 衢州 洛陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Asp.Mvc 2.0用戶服務(wù)器驗證實例講解(4)》,本文關(guān)鍵詞  Asp.Mvc,2.0,用戶,服務(wù)器,驗證,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Asp.Mvc 2.0用戶服務(wù)器驗證實例講解(4)》相關(guān)的同類信息!
  • 本頁收集關(guān)于Asp.Mvc 2.0用戶服務(wù)器驗證實例講解(4)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    色视频欧美一区二区三区| 亚洲免费电影在线| 蜜臀精品久久久久久蜜臀| 在线看黄色的网站| 欧美日韩国产一区| 亚洲综合一区在线| 国产成人精品一区二区三区在线观看| 在线一区二区三区四区五区| 亚洲人成网站影音先锋播放| www.欧美日韩| 在线观看视频一区二区| 亚洲精品亚洲人成人网在线播放| av爱爱亚洲一区| 在线观看欧美精品| 亚洲最色的网站| 在线观看免费视频黄| 欧美精品三级日韩久久| 婷婷中文字幕综合| 精品夜夜澡人妻无码av | 中文字幕日韩av资源站| 成人高清免费在线播放| 色又黄又爽网站www久久| 亚洲美女屁股眼交| 亚洲av熟女高潮一区二区| 日韩一区二区三| 韩国欧美国产一区| 国产午夜手机精彩视频| 亚洲激情av在线| www.啪啪.com| 精品av久久707| 高清国产午夜精品久久久久久| 国产午夜手机精彩视频| 亚洲综合男人的天堂| 好吊色视频一区二区三区| 精品国产电影一区二区| 丁香网亚洲国际| 欧美日韩一区二区三区视频| 美日韩黄色大片| 黄色录像免费观看| 亚洲一区影音先锋| 91成年人网站| 亚洲欧洲精品天堂一级| 日本69式三人交| 久久久久国产精品麻豆ai换脸| 国产精品一线二线三线精华| 在线中文字幕不卡| 免费视频最近日韩| 老熟妇高潮一区二区三区| 亚洲综合免费观看高清在线观看| 亚洲精品视频久久久| 中文字幕在线播放不卡一区| 最新版天堂资源在线| 久久女同精品一区二区| 91污片在线观看| 91麻豆精品国产综合久久久久久| 久草在线在线精品观看| 在线精品亚洲一区二区不卡| 免费观看30秒视频久久| 1024手机在线视频| 秋霞影院一区二区| 日本中文在线视频| 日韩中文字幕一区二区三区| 国精产品视频一二二区| 亚洲国产日韩一区二区| 亚洲女同二女同志奶水| 天天影视色香欲综合网老头| 秋霞欧美一区二区三区视频免费| 香蕉影视欧美成人| 国产精品久久久精品四季影院| 天涯成人国产亚洲精品一区av| 在线观看美女av| 美女一区二区视频| 日本韩国欧美一区| 狠狠色2019综合网| 欧美日韩国产综合久久| 春色校园综合激情亚洲| 精品日韩一区二区| 中文字幕无人区二| 国产精品沙发午睡系列990531| 久久久国产精品无码| 亚洲视频一二区| 奇米网一区二区| 日本网站在线观看一区二区三区| 久久精品国产精品亚洲红杏| 色哦色哦哦色天天综合| 国产中文一区二区三区| 91精品国产黑色紧身裤美女| 99久久精品免费| 日本一区二区三区四区在线视频| 国产肉体xxxx裸体784大胆| 亚洲精品亚洲人成人网| 免费国产羞羞网站美图| 韩国女主播成人在线| 欧美一区永久视频免费观看| 91丨porny丨国产入口| 国产精品毛片久久久久久| 91精彩刺激对白露脸偷拍| 亚洲国产精品一区二区久久恐怖片| 成人免费毛片xxx| 韩国女主播成人在线| 欧美成人三级在线| 欧产日产国产精品98| 一区二区高清在线| 色婷婷综合激情| 成人免费福利片| 欧美激情一区二区三区全黄 | 国产黑丝一区二区| 亚洲精品视频在线看| 老湿机69福利| 风流少妇一区二区| 国产精品欧美一级免费| 蜜桃av免费观看| 国产在线一区观看| 久久久久久久综合日本| 丰腴饱满的极品熟妇| 免费不卡在线观看| 精品女同一区二区| 97超碰在线资源| 蜜臀av在线播放一区二区三区| 欧美一区二区私人影院日本| 91精品啪在线观看国产| 天堂va蜜桃一区二区三区漫画版| 欧美欧美午夜aⅴ在线观看| 波多野结衣三级视频| 亚洲一二三四久久| 欧美日韩成人综合天天影院| av在线天堂网| 亚洲va天堂va国产va久| 这里是久久伊人| 无码人妻精品一区二区三应用大全| 日本色综合中文字幕| 日韩欧美高清一区| 精品国产av无码| 国内成人精品2018免费看| 国产亚洲一区二区在线观看| 欧美a级片免费看| 成人黄色电影在线| 亚洲精品福利视频网站| 欧美日韩精品久久久| 污污污www精品国产网站| 日本网站在线观看一区二区三区 | 日韩精品在线一区| 熟女俱乐部一区二区| 国产精品一二三四五| 中文字幕五月欧美| 欧美日韩国产美| 一本色道综合久久欧美日韩精品| 精品亚洲成a人| 国产精品久久午夜| 欧美视频精品在线| 国产白嫩美女无套久久| 久久97超碰国产精品超碰| 亚洲国产高清在线| 欧美熟乱第一页| 国产男女猛烈无遮挡a片漫画 | 91精品国产麻豆| 久久久久久久毛片| 成人小视频在线| 亚洲猫色日本管| 日韩视频在线永久播放| 一区二区三区在线播放视频| 91浏览器在线视频| 免费成人在线播放| 国产精品久久久久影院亚瑟| 欧美调教femdomvk| 在线免费看黄视频| 成人va在线观看| 日韩电影一二三区| 国产精品美日韩| 欧美精品日日鲁夜夜添| 夫妇露脸对白88av| gogo亚洲国模私拍人体| 麻豆精品国产91久久久久久| 中文字幕在线不卡一区| 欧美日韩国产免费一区二区| 国产精品无码无卡无需播放器| 94色蜜桃网一区二区三区| 青青草精品视频| 18欧美亚洲精品| 日韩欧美一区二区视频| 日韩成人短视频| 自拍视频一区二区| 粉嫩av一区二区三区| 天天综合色天天综合| 国产精品久线观看视频| 日韩视频免费观看高清完整版| 日本aⅴ在线观看| 日本aaa视频| 日本黄色www| 国产真实乱子伦精品视频| 亚洲不卡一区二区三区| 亚洲欧洲色图综合| 欧美mv日韩mv亚洲| 国产这里有精品| 人妻少妇无码精品视频区| 中文在线字幕观看| 成人黄色网址在线观看| 久久国产尿小便嘘嘘尿| 亚洲国产精品久久久久婷婷884 | 亚洲高清免费观看|