asp.net identity 2.2.0 中角色启用和基本使用(七)提示点
在使用asp.net identity 2.2.0 中,大家可能设计到一些修改和配置
关于Identity的配置,在App_Start文件中的IdentityConfig.cs中,这里几乎有你需要的一切东西。
一、常用的就是密码强度问题:
// 配置密码的验证逻辑
manager.PasswordValidator = new PasswordValidator
{
RequiredLength = 6, //设置密码长度最小为6
RequireNonLetterOrDigit = true, //设置密码是否需要一个非字母或数字字符。
RequireDigit = true, //设置密码是否需要一个数字(0”-“9”)。
RequireLowercase = true, //设置密码是否需要一个小写字母(A - Z)。
RequireUppercase = true, //设置密码是否需要一个大写字母(A - Z)。
};
二、注册时信箱转为用户名。
这里需要更改控制器,模型和视图
打开Controller目录下的AccountController.cs找到 public async Task<ActionResult> Register(RegisterViewModel model)这下面的var user = new ApplicationUser { UserName = model.Email, Email = model.Email };这里两个参数都是绑定的email。
1.把var user = new ApplicationUser { UserName = model.Email, Email = model.Email };改为var user = new ApplicationUser { UserName = model.UserName, Email = model.Email };
更改后vs会提示下红波浪线(错误),选择纠错为“生成属性”的哪一项。
2.vs将在Models文件夹下找AccountViewModels模型内的RegisterViewModel中的public class RegisterViewModel 中自动添加 public string UserName { get; set; },好了在上面堆你想要的规则吧。
例如:[Required]
[StringLength(20, ErrorMessage = "{0} 必须至少包含 {2} 个字符,最多20个字符。", MinimumLength = 6)]
[Display(Name = "用户账号")]
[DataType(DataType.Text)]
public string UserName { get; set; }
3.在Views文件夹中的register.cshtml文件中添加一组代码:
<div class="form-group">
@Html.LabelFor(m => m.UserName, new { @class = "col-md-2 control-label" })
<div class="col-md-10">
@Html.TextBoxFor(m => m.UserName, new { @class = "form-control" })
</div>
</div>
至此,这项修改就完成了,注册一个试试吧。
4、改完上面的,还要改下login的,因为改为了用户名注册,这里在用email登陆的话,一定出现错误。
首先在Models文件夹下找AccountViewModels模型内的loginViewModel中的public class loginViewModel 中自动添加 public string UesrName { get; set; },好了在上面堆你想要的规则吧。
例如:[Required]
[StringLength(20, ErrorMessage = "{0} 必须至少包含 {2} 个字符,最多20个字符。", MinimumLength = 6)]
[Display(Name = "用户账号")]
[DataType(DataType.Text)]
public string UserName { get; set; }
在这里设置好后,一定要把原来的email模型项去掉或者注释掉,否则你登陆不上去且还不给提示。
[Required]
[Display(Name = "电子邮件")]
[EmailAddress]
public string Email { get; set; }
5、之后在Views文件夹中的login.cshtml文件中原来为
<div class="form-group">
@Html.LabelFor(m => m.Email, new { @class = "col-md-2 control-label" })
<div class="col-md-10">
@Html.TextBoxFor(m => m.Email, new { @class = "form-control" })
@Html.ValidationMessageFor(m => m.Email, "", new { @class = "text-danger" })
</div>
</div>
改为
<div class="form-group">
@Html.LabelFor(m => m.UserName, new { @class = "col-md-2 control-label" })
<div class="col-md-10">
@Html.TextBoxFor(m => m.UserName, new { @class = "form-control" })
@Html.ValidationMessageFor(m => m.UserName, "", new { @class = "text-danger" })
</div>
</div>
6、打开AccountController.cs文件,找到 public async Task<ActionResult> Login(LoginViewModel model, string returnUrl)这个方法
把 var result = await SignInManager.PasswordSignInAsync(model.Email, model.Password, model.RememberMe, shouldLockout: false);
改为var result = await SignInManager.PasswordSignInAsync(model.UserName, model.Password, model.RememberMe, shouldLockout: false);
这样以后登陆和注册都改为用户名形式了。
三、修改用户管理中角色分配时使用用户名称
按照之前的步骤当大家操作“用户管理”中的编辑角色时会发现这里显示的是“电邮地址”而不是用户名。现在我们来改良这个问题。
1.打开“Models”中的“AdminViewModels.cs”文件,找到 “ EditUserViewModel”方法。
注释掉跟“Email”相关的代码并添加“UserName”属性,效果如下: (这里说下,个人喜欢注释掉代码,因为方便使用后悔药。喜欢绝对简洁的朋友,可以直接删除。)
//[Required(AllowEmptyStrings = false)]
//[Display(Name = "电邮地址")]
//[EmailAddress]
//public string Email { get; set; }
[Required(AllowEmptyStrings = false)]
[Display(Name = "用户名称")]
public string UserName { get; set; }
2、修改“controllers”文件夹中的“UserAdminController.cs”中的
原为“public async Task<ActionResult> Edit([Bind(Include = "Email,Id")]EditUserViewModel editUser, params string[] selectedRole)”
改为“public async Task<ActionResult> Edit([Bind(Include = "UserName,Id")]EditUserViewModel editUser, params string[] selectedRole)”
并注释掉该方法中的user.UserName = editUser.Email; user.Email = editUser.Email;然后添加上user.UserName = editUser.UserName;效果如下:
//user.UserName = editUser.Email; //user.Email = editUser.Email; user.UserName = editUser.UserName;
3.打开“Views”文件夹中修改“UsersAdmin”文件夹中的“edit.cshtml”文件中的代码。效果如下:
@*<div class="form-group">
@Html.LabelFor(model => model.Email, new { @class = "control-label col-md-2" })
<div class=" col-md-10">
@Html.TextBoxFor(model => model.Email, new { @class = "form-control" })
@Html.ValidationMessageFor(model => model.Email)
</div>*@
<div class="form-group">
@Html.LabelFor(model => model.UserName, new { @class = "control-label col-md-2" })
<div class=" col-md-10">
@Html.TextBoxFor(model => model.UserName, new { @class = "form-control" })
@Html.ValidationMessageFor(model => model.UserName)
</div>
</div>
至此,用户管理中的“编辑角色”显示的将是用户名了。
四、注册用户的同时将注册用户分配到默认角色中。
1、执行这步以前,需要准备好相关的角色。
2、打开“controllers”文件夹中的“accountcontroller.cs”找到“public async Task<ActionResult> Register(RegisterViewModel model)”方法,并在该方法内添加如下代码,完成后效果如下:
public async Task<ActionResult> Register(RegisterViewModel model)
{
if (ModelState.IsValid)
{
var user = new ApplicationUser { UserName = model.UserName, Email = model.Email };
var result = await UserManager.CreateAsync(user, model.Password);
if (result.Succeeded)
{
await SignInManager.SignInAsync(user, isPersistent:false, rememberBrowser:false);
//将注册用户分配默认的角色
var rolesForUser = UserManager.GetRoles(user.Id);
if (!rolesForUser.Contains("普通用户"))
{
UserManager.AddToRole(user.Id, "普通用户");
}
// 有关如何启用帐户确认和密码重置的详细信息,请访问 http://go.microsoft.com/fwlink/?LinkID=320771
// 发送包含此链接的电子邮件
// string code = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id);
// var callbackUrl = Url.Action("ConfirmEmail", "Account", new { userId = user.Id, code = code }, protocol: Request.Url.Scheme);
// await UserManager.SendEmailAsync(user.Id, "确认你的帐户", "请通过单击 <a href=\"" + callbackUrl + "\">這裏</a>来确认你的帐户");
return RedirectToAction("Index", "Home");
}
AddErrors(result);
}
// 如果我们进行到这一步时某个地方出错,则重新显示表单
return View(model);
}
好了,注册个用户看看吧。
asp.net identity 2.2.0 中角色启用和基本使用(七)提示点的更多相关文章
- asp.net identity 2.2.0 中角色启用和基本使用(六)
创建用户管理相关视图 第一步:添加视图 打开UsersAdminController.cs 将鼠标移动到public ActionResult Index()上 右键>添加视图 系 ...
- asp.net identity 2.2.0 中角色启用和基本使用(四)
创建角色相关视图 第一步:添加视图 打开RolesAdminController.cs 将鼠标移动到public ActionResult Index()上 右键>添加视图 系统会 ...
- asp.net identity 2.2.0 中角色启用和基本使用(三)
创建控制器 第一步:在controllers文件夹上点右键>添加>控制器, 我这里选的是“MVC5 控制器-空”,名称设置为:RolesAdminController.cs 第二步:添加命 ...
- asp.net identity 2.2.0 中角色启用和基本使用(五)
建立控制器UsersAdminController 第一步:在controllers文件夹上点右键>添加>控制器, 我这里选的是“MVC5 控制器-空”,名称设置为:UsersAdminC ...
- asp.net identity 2.2.0 中角色启用和基本使用(二)
建立模型 第一步:在Models文件夹上点右键 >添加>类 类的名称自定,我用AdminViewModels命名的 因为是讲基本使用,我这里不做任何扩展. 第二步:添加如下命名空间 ...
- ASP.NET Identity 身份验证和基于角色的授权
ASP.NET Identity 身份验证和基于角色的授权 阅读目录 探索身份验证与授权 使用ASP.NET Identity 身份验证 使用角色进行授权 初始化数据,Seeding 数据库 小结 在 ...
- MyEclipse6.0中使用aptana插件,添加jquery提示功能
MyEclipse6.0中使用aptana插件,添加jquery提示功能 第一:查看当前MyEclipse集成的eclipse的版本,, 查看路径 D:/MyEclipse 6.0/eclips ...
- asp.net identity 2.2.0 在MVC下的角色启用和基本使用(一)
基本环境:asp.net 4.5.2 第一步:在App_Start文件夹中的IdentityConfig.cs中添加角色控制器. 在namespace xxx内(即最后一个“}”前面)添加 角色控制类 ...
- ASP.NET MVC 随想录——探索ASP.NET Identity 身份验证和基于角色的授权,中级篇
在前一篇文章中,我介绍了ASP.NET Identity 基本API的运用并创建了若干用户账号.那么在本篇文章中,我将继续ASP.NET Identity 之旅,向您展示如何运用ASP.NET Ide ...
随机推荐
- shell中命令之间数据的传递
1.管道 "|" ls | cat -n > out.txt 2. 子shell 2.1 子shell 说明 在shell脚本中可以用()操作符可以定义一个子shell #/ ...
- MFC 设置控件事件对应的函数
在项目中,右击你想设置的控件,打开属性. 然后找到:控件事件,如果在Visual Studio 2015中操作,显示如图: 然后,以设定单击事件为例: 点击右边的三角,选择 <Edit Code ...
- 疯狂java笔记(七) - Java集合之Map
Map是以键值对(key-value)的形式来存储数据的.而且Map不允许key的重复,通过Map存储key-value对时,只需要考虑key的存储就可以,key存储后value就会跟着key(完全可 ...
- 生理周期[PKU1006]
生理周期 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 132195 Accepted: 42171 Descripti ...
- spark-sql访问hive的问题记录
好久没有弄博客了... hive0.14 spark0.12 [hadoop@irs bin]$ ./spark-sql Spark assembly has been built with Hive ...
- webpack练手项目之easySlide(二):代码分割(转)
在上一篇 webpack练手项目之easySlide(一):初探webpack 中我们一起为大家介绍了webpack的基本用法,使用webpack对前端代码进行模块化打包. 但是乍一看webpack ...
- OpenResty 安装 drizzle-nginx-module
1.下载drizzle模块 wget http://openresty.org/download/drizzle7-2011.07.21.tar.gz 2.安装drizzle模块 tar zxvf d ...
- c 语言结构体的三种定义方式
struct 结构体名{ 成员列表: ..... }结构体变量: 结构体类型变量的定义 结构体类型变量的定义与其它类型的变量的定义是一样的,但由于结构体类型需要针对问题事先自行定义,所以结构体 ...
- 【BZOJ3343】教主的魔法 分块+二分
Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了一起,这次他们排成了一列,被编号为1.2.…….N. 每个人的 ...
- 【noiOJ】p1481
1481:Maximum sum 查看 提交 统计 提问 总时间限制: 1000ms 内存限制: 65536kB 描述 Given a set of n integers: A={a1, a2,. ...