如何在 MVC 5 中使用用户身份中的角色
Posted
技术标签:
【中文标题】如何在 MVC 5 中使用用户身份中的角色【英文标题】:How to use Roles in user identity in MVC 5 【发布时间】:2014-12-11 13:48:08 【问题描述】:我想在 mvc 5 中使用 asp.net 用户身份,我执行以下步骤:
1) 创建一个 mvc 项目。
2) 创建我自己的数据库并更改 web.config 形式的连接字符串: 到:
3) 我运行项目并创建一个新用户以将相关表添加到我的数据库中。
4) 我想在 accountControler 中注册用户后添加一个角色,如下代码:
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) 我加了
<roleManager enabled="true">
进入:
<system.web></system.web>
当我创建一个新用户时,我的用户注册良好但用户没有添加到角色中,当我这样做时 VS 在 App_Data 中创建一个名为“ASPNETDB.MDF”的新数据库。 所以我找到了一篇新文章,解释了 web.config 中的角色提供者设置,并且:
6) 我加了
<roleManager enabled="true">
<providers>
<clear/>
<add name="AspNetSqlRoleProvider" connectionStringName="DefaultConnection" applicationName="/" type="System.Web.Security.SqlRoleProvider, System.Web, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"/>
</providers>
</roleManager>
进入:
<system.web></system.web>
但是当我想注册新用户时,我发现了这个错误:
找不到存储过程“dbo.aspnet_CheckSchemaVersion”。
现在我认为我的问题是当我执行第 3 步时,它不会完全创建用户身份数据库和存储过程!我是否对 MVC 5 使用角色 true ?请帮我解决这个问题!
【问题讨论】:
通常代表率低的人不会花太多精力来写他们的问题,但是伙计,你是明星!为问题清晰而投票! 【参考方案1】:当你写作时
!Roles.RoleExists("Member")
您没有使用 ASP.NET Identity!相反,您应该使用 ApplicationRole
以便它扩展 IdentityRole
类
另外,你不需要在你的配置文件中告诉AspNetSqlRoleProvider
。 Asp.Net Identity 是不同的。在 Asp.Net Identity 的 App_Start 文件夹中有一个名为 ApplicationRoleManager
的类。
您不应该使用 Asp.Net Identity,就好像它是旧的简单成员一样。
或者,查看 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
所有这些都是由 Microsoft 身份团队之一的 Pranav Rastogi
为您完成的。
请注意,对于这些示例,您的目标是 System.Web.Mvc 的新(测试版)版本,它比 System.Web.Mvc 5.0.0.0 更新如果我没记错的话,测试版是 System.Web.MVC 5.0.1.2或者类似的东西
了解更多关于身份click here
更新 示例中的版本为:System.Web.Mvc 5.2.1.0
【讨论】:
仅供参考 MVC 5.2.0 已经发布了一段时间以上是关于如何在 MVC 5 中使用用户身份中的角色的主要内容,如果未能解决你的问题,请参考以下文章
如何在 MVC 5 应用程序中存储用户数据? (使用 Windows 身份验证)