asp.net-mvc – 如何在MVC 5中使用用户身份中的角色
我想在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”的新数据库. 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> 但是当我想注册新用户时,我发现了这个错误:
现在我认为我的问题是当我执行第3步时它不会完全创建用户身份数据库和存储过程!我对MVC 5使用的角色是真的吗?请帮我解决这个问题! 解决方法
当你写作
!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) 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 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 – 我可以在服务器端调用CustomValidator方法而无需
- asp.net-mvc – 我应该在LogOff方法中使用Session.Abandon(
- asp.net-mvc – Url.RouteUrl返回null
- asp.net-mvc – [HttpPost] public ActionResult Create(Fo
- 如何处理在MVC视图中应用程序启动和传输和显示错误发生的AS
- asp.net-mvc – 如何从ASP.NET MVC中的JSONResult方法重定向
- 线程机制、CLR线程池以及应用程序域
- asp.net-mvc – 带有淘汰赛的EditorFor HTML Helper
- .net – 绕过获取请求的MVC验证
- efcore 新特性 SaveChanges Events
- asp.net – ASP:NET确认密码字段
- asp.net – 如何调用一个特定的UpdatePanel加载后
- asp.net – 在网页中显示OLAP SQL Server?
- asp.net mvc 中使用async/await异步编程
- asp.net – Umbraco神奇地回归到“看起来还有更多
- asp.net-mvc – ASP.NET Web API – Windows窗体
- asp.net-mvc-4 – Razor模板编辑器不喜欢我的Kno
- ASP.NET / VB中的jsFiddle是否相当?
- 在ASP.net中使用NVP API时,PayPal SetExpressChe
- 实现ASP.NET MVC的自定义登录