gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 13:34:35 24 4
gpt4 key购买 nike

我想在 mvc 5 中使用 asp.net useridentity,我执行以下步骤:

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>

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

Could not find stored procedure '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 的测试版(这意味着事情可能会发生变化),以了解有关如何在 Identity 中执行操作的更多信息。

以下是如何开始:

  • 创建一个新项目:选择空模板(不是 MVC 也不是 WebForm)
  • 通过 nuget 安装 Asp.Net 身份示例

    PM> Install-Package Microsoft.AspNet.Identity.Samples -Pre
  • 编辑命名空间以匹配您的旧项目命名空间
  • 如果您想将旧项目中的某些文件夹复制到新项目,请复制您的( Controller 、 View ……)而不是配置文件。

在这里您可以创建角色,如下所示:

            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 5.0.0.0 更新的 System.Web.Mvc 新(测试版)版本如果我没记错的话,测试版是 System.Web.MVC 5.0.1.2或类似的东西

了解有关身份的更多信息 click here

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

关于asp.net-mvc - 如何在 MVC 5 中的用户身份中使用角色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26400251/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com