asp.net-mvc – 如何在MVC 5中使用用户身份中的角色

前端之家收集整理的这篇文章主要介绍了asp.net-mvc – 如何在MVC 5中使用用户身份中的角色前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想在mvc 5中使用asp.net useridentity,我执行以下步骤:

1)创建一个mvc项目.

2)创建我自己的数据库并更改web.config格式的连接字符串:



至:


3)我运行项目并创建一个新用户将相关表添加到我的数据库.

4)我想在accountControler中注册像此代码之类的用户后向用户添加角色:

  1. public async Task<ActionResult> Register(Registerviewmodel model)
  2. {
  3. if (ModelState.IsValid)
  4. {
  5. var user = new ApplicationUser() { UserName = model.Email,Email = model.Email };
  6.  
  7. IdentityResult result = await UserManager.CreateAsync(user,model.Password);
  8. if (result.Succeeded)
  9. {
  10. //******************* Add Role To User **************
  11. if (!Roles.RoleExists("Member"))
  12. Roles.CreateRole("Member");
  13. Roles.AddUserToRole(model.Email,"Member");
  14. //****************************************************
  15.  
  16. await SignInAsync(user,isPersistent: false);
  17. // For more information on how to enable account confirmation and password reset please visit http://go.microsoft.com/fwlink/?LinkID=320771
  18. // Send an email with this link
  19. // string code = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id);
  20. // var callbackUrl = Url.Action("ConfirmEmail","Account",new { userId = user.Id,code = code },protocol: Request.Url.Scheme);
  21. // await UserManager.SendEmailAsync(user.Id,"Confirm your account","Please confirm your account by clicking <a href=\"" + callbackUrl + "\">here</a>");
  22.  
  23. return RedirectToAction("Index","Home");
  24. }
  25. else
  26. {
  27. AddErrors(result);
  28. }
  29. }
  30.  
  31. // If we got this far,something Failed,redisplay form
  32. return View(model);
  33. }

5)我补充说

  1. <roleManager enabled="true">

成:

  1. <system.web></system.web>

当我创建一个新用户时,我的用户注册得很好但用户没有添加到该角色,当我这样做时VS在App_Data中创建一个名为“ASPNETDB.MDF”的新数据库.
所以我发现了一篇新文章,解释了web.config中的角色提供者设置和:

6)我补充说

  1. <roleManager enabled="true">
  2. <providers>
  3. <clear/>
  4. <add name="AspNetsqlRoleProvider" connectionStringName="DefaultConnection" applicationName="/" type="System.Web.Security.sqlRoleProvider,System.Web,Version=2.0.0.0,Culture=neutral,PublicKeyToken=b03f5f7f11d50a3a"/>
  5. </providers>
  6. </roleManager>

进入:

  1. <system.web></system.web>

但是当我想注册新用户时,我发现了这个错误

Could not find stored procedure ‘dbo.aspnet_CheckSchemaVersion’.

现在我认为我的问题是当我执行第3步时它不会完全创建用户身份数据库和存储过程!我对MVC 5使用的角色是真的吗?请帮我解决这个问题!

解决方法

当你写作
  1. !Roles.RoleExists("Member")

你没有使用ASP.NET身份!相反,你应该使用ApplicationRole,因此它扩展了IdentityRole类

此外,您不需要在配置文件中告诉AspNetsqlRoleProvider. Asp.Net Identity是不同的东西.在Asp.Net Identity中,App_Start文件夹中有一个名为ApplicationRoleManager的类.

您不应该使用Asp.Net Identity,就好像它是旧的简单成员资格一样.

或者,检查身份证的beta版(这意味着可能会发生变化)以了解有关如何在身份中进行操作的更多信息.

以下是如何开始:

>创建一个新项目:选择Empty template(Not MVC not WebForm)
>通过nuget安装Asp.Net标识样本

  1. PM> Install-Package Microsoft.AspNet.Identity.Samples -Pre

>编辑命名空间以匹配旧的项目命名空间
>如果要将旧项目中的某些文件夹复制到新项目,请复制(控制器,视图,…)而不是配置文件.

您可以在此处创建角色,如下所示:

  1. var role = new IdentityRole("roleName");
  2. var roleresult = await RoleManager.CreateAsync(role);

并创建用户并将其添加到您将使用此角色的特定角色

  1. var user = new ApplicationUser
  2. {
  3. UserName = "tresorunikin",Email = "tresorunikin@bellashada.com",EmailConfirmed =true
  4. };
  5.  
  6. var userResult = await UserManager.CreateAsync(user,"123@Strong.Password");
  7. if(userResult.Succeeded){
  8. string[] roles =new string[]{"admin","seller","other"};
  9. var roleResult = await UserManager.AddToRolesAsync(user.Id,roles);
  10. if(roleResult.Succeeded){
  11. //Here,user has been added to roles
  12. }
  13. }

所有这些都是由微软的身份团队之一Pranav Rastogi为您完成的.

请注意,使用这些示例,您将定位比System.Web.Mvc 5.0.0.0更新的System.Web.Mvc的新(测试版)版本如果我记得很好,测试版是System.Web.MVC 5.0.1.2或类似的东西那

要了解有关Identity click here的更多信息

更新样本中的版本是:System.Web.Mvc 5.2.1.0

猜你在找的asp.Net相关文章