[Authorize(Roles = "Role1")] public async Task<ActionResult> Action() { var currentUser = AuthenticationManager.User; var currentUserID = currentUser.IDentity.GetUserID(); var result = await UserManager.AddToRoleAsync(currentUserID,"Role2"); //result confirms role added return RedirectToAction("AnotherAction","Controller"); } // not accessible until relog [Authorize(Roles = "Role2")] public ActionResult AnotherAction() { return VIEw(); }
如何使角色更改立即生效?
解决方法 我相信AddUserToRole方法在数据库级别执行赋值.虽然这可能也需要发生,但您需要做的是刷新当前身份.简短回答:将IPrincipal投射到ClaimsPrincipal并将IIDentity转换为ClaimsIDentity.然后你可以添加声明.
ClaimsPrincipal currentPrincipal = (ClaimsPrincipal)this.User; ClaimsIDentity currentIDentity = (ClaimsIDentity)currentPrincipal.IDentity; currentIDentity.AddClaim(new Claim(ClaimTypes.Role,"Role2"));总结
以上是内存溢出为你收集整理的c# – 如何为登录用户添加和启用OWIN角色?全部内容,希望文章能够帮你解决c# – 如何为登录用户添加和启用OWIN角色?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)