我将用户添加到角色中,如下所示(请注意,我在我的机器上运行如下所示的代码):
Roles.AddUserToRole(oMU.UserName, "Role1");使用下面的代码,我检查用户是否属于该角色:
if (Roles.IsUserInRole(txtUserName.Text.Trim(), "Role1")) 并且该用户确实在该角色中。
我运行以下命令来检查当前登录的用户是否在Role1中,但它无法输入if语句-为什么?
if (User.IsUserInRole("Role1"))
{
// does not enter this code
}发布于 2013-04-20 03:27:10
您不能调用Roles.IsUserInRole("Role1")
一旦用户被分配到像这样的角色-
Roles.AddUserToRole(oMU.UserName, "Role1");为什么?
IPrincipal object仅在Application_AuthenticateRequest上注入到HttpContext.Current.User。
因此,您必须等待下一个请求才能访问Roles.IsUserInRole("Role1")。
已更新
确保将cacheRolesInCookie设置为false,因为它有一些问题。
<roleManager enabled="true" cacheRolesInCookie="false"
defaultProvider="DefaultRoleProvider">
....
</roleManager>发布于 2013-04-20 03:13:41
我认为它应该是User.IsInRole而不是Roles.IsUserInRole,或者通过传递Roles.IsUserInRole(User.Identity.Name,"Role1")来明确指定用户名作为参数
带有一个参数的Roles.IsUserInRole为用户名调用GetCurrentUser(),这将从CurrentPrincipal中提取用户名。听起来您当前登录的用户与当前主体上的用户不同。
https://stackoverflow.com/questions/16111886
复制相似问题