Asp.Net Identity 深度解析 之 註冊登陸的擴展

  關於權限每一個系統都有本身的解決方案,今天咱們來討論一下微軟的權限框架Asp.Net Identity ,介紹以下  http://www.asp.net/identity 這裏不在贅餘。html

  不少人認爲 Asp.Net Identity 很差用,很難控制,其實否則,若是去認真研究會發現很好用,如今咱們一塊兒來學習這套權限框架。數據庫

  我這裏的環境是VS2013 Update 3, 因此新建一個MVC5項目的時候 Asp.Net Identity 是2.0版本。框架

 

  項目新建完成後咱們運行一下 先看一下注冊:asp.net

    

這裏是使用電子郵件做爲登陸名使用,和前一版本有所區別,若是你認爲還可使用111111做爲密碼那就錯大了。異步

密碼難度明顯提高,你也許或想,我不須要真麼高強度的密碼,我就想要111111做爲密碼,彆着急,後面博客會有介紹.async

 輸入郵箱和密碼就能夠註冊成功 。ide

關鍵代碼入下: 學習

   

   增長了不少異步操做。spa

 如今咱們來擴展這個註冊功能,加入更加真實的數據.net

 找到RegisterViewModel.cs 添加入下代碼:

 #region 擴展
       
        [Display(Name = "用戶名")]
        public string UserName { get; set; }

       
        [Display(Name = "電話(手機/固話)")]
        [Phone]
        public string PhoneNumber { get; set; }
        #endregion

 

 而後咱們修改Register.cshtml  添加以下代碼:

 1   <div class="form-group">
 2                 @Html.LabelFor(m => m.UserName, new { @class = "col-md-2 control-label" })
 3                 <div class="col-md-10">
 4                     @Html.TextBoxFor(m => m.UserName, new { @class = "form-control" })
 5                 </div>
 6             </div>
 7             <div class="form-group">
 8                 @Html.LabelFor(m => m.PhoneNumber, new { @class = "col-md-2 control-label" })
 9                 <div class="col-md-10">
10                     @Html.TextBoxFor(m => m.PhoneNumber, new { @class = "form-control" })
11                 </div>
12             </div>

 下面咱們來看一下效果

  

 

 到這裏咱們的擴展基本結束,咱們來修改擴展後的Register Action 

新建一個 RegisterExtension Action 

  

 1  [HttpPost]
 2         [AllowAnonymous]
 3         [ValidateAntiForgeryToken]
 4         public async Task<ActionResult> RegisterExtension(RegisterViewModel model)
 5         {
 6             if (ModelState.IsValid)
 7             {
//這裏是擴展的代碼
8 var user = new ApplicationUser { UserName = model.UserName, Email = model.Email, PhoneNumber = model.PhoneNumber };
9 var result = await UserManager.CreateAsync(user, model.Password); 10 if (result.Succeeded) 11 { 12 await SignInManager.SignInAsync(user, isPersistent: false, rememberBrowser: false); 13 // 有關如何啓用賬戶確認和密碼重置的詳細信息,請訪問 http://go.microsoft.com/fwlink/?LinkID=320771 14 // 發送包含此連接的電子郵件 15 // string code = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id); 16 // var callbackUrl = Url.Action("ConfirmEmail", "Account", new { userId = user.Id, code = code }, protocol: Request.Url.Scheme); 17 // await UserManager.SendEmailAsync(user.Id, "確認你的賬戶", "請經過單擊 <a href=\"" + callbackUrl + "\">這裏</a>來確認你的賬戶"); 18 return RedirectToAction("Index", "Home"); 19 } 20 AddErrors(result); 21 } 22 // 若是咱們進行到這一步時某個地方出錯,則從新顯示錶單 23 return View(model); 24 }

 細心的朋友可能已經注意到 ,數據庫字段並無作修改,是由於 數據庫中有UserName,和PhoneNumber 這兩個字段

運行項目查看效果 :

 

點擊註冊後 效果以下 

註冊成功,登錄成功,如今咱們的一個註冊擴展已經完成了。

若是你想要在登錄頁面將郵箱改成用戶名,咱們能夠這樣作:

  修改Login.cshtml 和 Login Action 將 Email ==> UserName 便可。

下一篇,咱們將會討論 如何添加角色,以及如何爲用戶添加角色,敬請期待,文章中若有問題歡迎指出。

 

   

 

相關文章
相關標籤/搜索