Asp.net mvc 如何在MVC5中使用用户标识中的角色
我想在mvc 5中使用asp.net useridentity,我执行以下步骤: 1) 创建一个mvc项目 2) 创建我自己的数据库并更改web.config表单中的connectionstring: 致: 3) 我运行该项目并创建一个新用户,将相关表添加到我的数据库中 4) 在AccountController中注册用户后,我想向用户添加一个角色,如下代码:Asp.net mvc 如何在MVC5中使用用户标识中的角色,asp.net-mvc,asp.net-mvc-5,asp.net-identity,user-roles,Asp.net Mvc,Asp.net Mvc 5,Asp.net Identity,User Roles,我想在mvc 5中使用asp.net useridentity,我执行以下步骤: 1) 创建一个mvc项目 2) 创建我自己的数据库并更改web.config表单中的connectionstring: 致: 3) 我运行该项目并创建一个新用户,将相关表添加到我的数据库中 4) 在AccountController中注册用户后,我想向用户添加一个角色,如下代码: public async Task<ActionResult> Register(RegisterViewModel mo
public async Task<ActionResult> Register(RegisterViewModel model)
{
if (ModelState.IsValid)
{
var user = new ApplicationUser() { UserName = model.Email, Email = model.Email };
IdentityResult result = await UserManager.CreateAsync(user, model.Password);
if (result.Succeeded)
{
//******************* Add Role To User **************
if (!Roles.RoleExists("Member"))
Roles.CreateRole("Member");
Roles.AddUserToRole(model.Email, "Member");
//****************************************************
await SignInAsync(user, isPersistent: false);
// For more information on how to enable account confirmation and password reset please visit http://go.microsoft.com/fwlink/?LinkID=320771
// Send an email with this link
// 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, "Confirm your account", "Please confirm your account by clicking <a href=\"" + callbackUrl + "\">here</a>");
return RedirectToAction("Index", "Home");
}
else
{
AddErrors(result);
}
}
// If we got this far, something failed, redisplay form
return View(model);
}
公共异步任务);
返回重定向到操作(“索引”、“主页”);
}
其他的
{
加法器(结果);
}
}
//如果我们走到这一步,有些东西失败了,重新显示形式
返回视图(模型);
}
5) 我补充说
进入:
当我创建一个新用户时,我的用户注册良好,但用户没有添加到角色,当我这样做时,我将在App_Data中创建一个名为“ASPNETDB.MDF”的新数据库。
因此,我发现了一篇新文章,解释了web.config中的角色提供程序设置,并:
6) 我补充说
进入:
<system.web></system.web>
但当我想注册新用户时,我发现了以下错误:
找不到存储过程“dbo.aspnet\u CheckSchemaVersion”
现在我想我的问题是,当我执行步骤3时,它不会完全创建用户身份数据库和存储过程!我是否在MVC 5中使用role true?请帮助我解决这个问题!当您编写
!Roles.RoleExists("Member")
您没有使用ASP.NET Identity!相反,您应该使用ApplicationRole
,以便它扩展IdentityRole
类
此外,您不需要告诉配置文件中的AspNetSqlRoleProvider
。Asp.Net标识与此不同。在Asp.Net标识中,App\u开始文件夹中有一个名为ApplicationRoleManager
的类
您不应该像使用旧的简单成员身份一样使用Asp.Net标识
或者,检查Identity的beta版(这意味着事情可能会改变),以了解如何在Identity中执行更多操作
以下是如何开始:
- 创建新项目:选择空模板(不是MVC不是WebForm)
- 通过nuget安装Asp.Net标识示例
PM> Install-Package Microsoft.AspNet.Identity.Samples -Pre
- 编辑命名空间以匹配旧项目命名空间
- 如果要将一些文件夹从旧项目复制到新项目,请复制(控制器、视图等)而不是配置文件
var role = new IdentityRole("roleName");
var roleresult = await RoleManager.CreateAsync(role);
要创建用户并将其添加到特定角色,您将使用
var user = new ApplicationUser
{
UserName = "tresorunikin",
Email = "tresorunikin@bellashada.com",
EmailConfirmed =true
};
var userResult = await UserManager.CreateAsync(user, "123@Strong.Password");
if(userResult.Succeeded){
string[] roles =new string[]{"admin","seller","other"};
var roleResult = await UserManager.AddToRolesAsync(user.Id, roles);
if(roleResult.Succeeded){
//Here, user has been added to roles
}
}
所有这些都是由微软的身份团队之一Pranav Rastogi为您完成的
请注意,通过这些示例,您的目标是System.Web.Mvc的一个新(beta)版本,它比System.Web.Mvc 5.0.0.0更新,如果我记得很清楚的话,beta版本是System.Web.Mvc 5.0.1.2或类似的版本
了解更多关于身份的信息
更新
示例中的版本是:System.Web.Mvc 5.2.1.0通常代表性较低的人在写问题时不会花太多精力,但伙计,你是个明星!!为了问题的清晰性,大家投票支持!!仅供参考,Mvc 5.2.0已经发布一段时间了
PM> Install-Package Microsoft.AspNet.Identity.Samples -Pre
var role = new IdentityRole("roleName");
var roleresult = await RoleManager.CreateAsync(role);
var user = new ApplicationUser
{
UserName = "tresorunikin",
Email = "tresorunikin@bellashada.com",
EmailConfirmed =true
};
var userResult = await UserManager.CreateAsync(user, "123@Strong.Password");
if(userResult.Succeeded){
string[] roles =new string[]{"admin","seller","other"};
var roleResult = await UserManager.AddToRolesAsync(user.Id, roles);
if(roleResult.Succeeded){
//Here, user has been added to roles
}
}