如何在MVC 5中使用用户身份中的角色



我想在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吗?请帮我解决这个问题!

当您编写时

 !Roles.RoleExists("Member") 

您没有使用ASP.NET Identity!相反,您应该使用ApplicationRole,以便它扩展IdentityRole

此外,您不需要告诉配置文件中的AspNetSqlRoleProvider。Asp.Net Identity则有所不同。在Asp.Net Identity中,App_Start文件夹中有一个名为ApplicationRoleManager的类。

您不应该像使用旧的简单成员身份一样使用Asp.Net标识。

或者,查看Identity的测试版(这意味着事情可能会改变),了解更多关于如何在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的新(测试版)版本,该版本比System.Web.Mvc 5.0.0.0更新。如果我记得很清楚,测试版是System.Web.VC 5.0.1.2或类似的版本

要了解有关身份的更多信息,请单击此处

更新示例中的版本为:System.Web.Mvc 5.2.1.0

相关内容

  • 没有找到相关文章