关于权限每一个系统都有本身的解决方案,今天咱们来讨论一下微软的权限框架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 便可。
下一篇,咱们将会讨论 如何添加角色,以及如何为用户添加角色,敬请期待,文章中若有问题欢迎指出。