溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何實現Asp.Mvc 2.0用戶服務器驗證

發(fā)布時間:2021-09-28 10:16:09 來源:億速云 閱讀:134 作者:iii 欄目:開發(fā)技術

這篇文章主要講解了“如何實現Asp.Mvc 2.0用戶服務器驗證”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何實現Asp.Mvc 2.0用戶服務器驗證”吧!

關于服務器端驗證,主要調用System.ComponentModel.DataAnnotations命名空間里面的類庫。
咱們這次還是以注冊頁面為例來講解服務器端驗證,主要對注冊頁面完成以下驗證
1.用戶名不能為空
2.密碼不能為空,密碼長度不能小于5位數,
3.密碼和確認密碼輸入必須一樣
4.郵件格式必須正確
咱們先看下效果圖

如何實現Asp.Mvc 2.0用戶服務器驗證

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

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

Required里面的參數表示具體的提示信息,此時如果用戶名為空,就會在前臺ASPX頁面出現用戶名不能為空的提示。當然要在前臺顯示錯誤的提示信息。使用<%:Html.ValidationMessageFor(m=>m.UserName)%>標記就可以在前臺顯示錯誤的提示信息
2.密碼驗證
密碼驗證包括密碼不能為空和密碼長度限制。
驗證密碼為空和驗證用戶名為空一樣,使用Required屬性。
驗證密碼的長度使用StringLength屬性。

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

StringLength的第一個參數表示密碼的最大長度,ErrorMessage表示不滿足條件的時候的錯誤提示信息。
MinimumLength表示輸入內容的最小長度.
當然,前臺必須有地方顯示錯誤信息,顯示錯誤信息我們使用如下
<%:Html.ValidationMessageFor(m=>m.UserPwd)%>
3.驗證密碼和確認密碼是否一致
要驗證密碼和確認密碼是否一致,這個稍微有點復雜,需要我們自定義驗證規(guī)則。自定義驗證規(guī)則我們需要繼承ValidationAttribute類.然后實現它的isvaild方法。

/// <summary> 
 /// 此自定義類用于驗證密碼和確認密碼必須一致 
 /// </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; }//確認密碼 
 
 
  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);//獲取確認密碼的值 
   return Object.Equals(originalValue, confirmValue); 
 
  } 
 } 

 
 PwdMatch屬性類創(chuàng)建后,可把它標記在注冊MODEL的上面,然后提交注冊的時候,就會驗證了
 [PwdMatch("UserPwd","ConfirPwd", ErrorMessage ="密¨&sup1;碼?與&reg;?確¨&iexcl;¤認¨?不?匹&pound;¤配?")]
 public class RegisterModel
{
 
}

PwdMatch的第一個參數表上密碼,名稱與RegisterModel中的密碼屬性相同,第二個字段是確認密碼,名稱與RegisterModel與的確認密碼屬性相同,最后一個參數是錯誤提示信息。
當然,也要在前臺顯示錯誤提示信息,使用<%:Html.ValidationSummary(true,"用&reg;?戶&iexcl;ì創(chuàng)&auml;&iexcl;&auml;建&iexcl;§失&ordm;&iexcl;ì敗&atilde;¨&sup1;!")%>就可以在前臺顯示一個總的錯誤信息列表。
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; 
  }

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

/// <summary> 
 /// 注冊用戶MODEL 
 /// </summary> 
 [PwdMatch("UserPwd", "ConfirPwd", ErrorMessage = "密碼與確認不匹配")] 
 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("確認密碼")] 
  [Required(ErrorMessage="確認密碼不能為空!")] 
  [StringLength(10, ErrorMessage = "確認密碼長度不能小于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> 
 /// 此自定義類用于驗證密碼和確認密碼必須一致 
 /// </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; }//確認密碼 
 
 
  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);//獲取確認密碼的值 
   return Object.Equals(originalValue, confirmValue); 
 
  } 
 }

前臺頁面代碼

<%@ Page Language="C#" Inherits="System.Web.Mvc.ViewPage<MvcLogin.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'>確認密碼不能為空!<span>", 
//     minlength: jQuery.format("確認密碼長度不能小于{0}個字符!"), 
//     equalTo: "<span style='color:red'>兩次輸入密碼不一致!</span>" 
 
//    }, 
//    Email: 
//    { 
//     email: "<span style='color:red'>郵箱輸入格式不正確!</span>" 
//    } 
//   }, 
//   onkeyup: false 
//  }); 
 
//  }); 
 </script> 
</head> 
<body> 
 <div> 
 <br /> 
 
 <p > 
 
 <%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) 
   { 
    //添加成功轉向主頁 
    FormsService.SignIn(model.UserName, false); 
    return RedirectToAction("index"); 
   } 
   else 
   { 
    //返回注冊頁面 
    ViewData["msg"] = "添加用戶失敗"; 
    return View(model); 
   } 
 
  } 
  else 
  { 
   //驗證不通過 
   //返回注冊頁面 
   ViewData["msg"] = "添加用戶失敗"; 
   return View(model); 
  } 
 }

感謝各位的閱讀,以上就是“如何實現Asp.Mvc 2.0用戶服務器驗證”的內容了,經過本文的學習后,相信大家對如何實現Asp.Mvc 2.0用戶服務器驗證這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI