我使用DataContext将roleprovider设置如下。在我的视图中,我有以下用户控件...
<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl" %>
<%
if (Request.IsAuthenticated) {
%>
Welcome <b><%= Html.Encode(Page.User.Identity.Name) %></b>!
<%= Html.ActionLink("Logout", "Logout", "Membership") %> | (
<%
var roles = System.Web.Security.Roles.GetRolesForUser(Page.User.Identity.Name);
foreach (string role in roles)
Html.Encode(role);
%>
)
现在,如果我在本地机器上运行它,它可以正常工作。请注意,连接到与我的远程盒子相同的数据库。它登录,并显示成员所属的角色。
如果我在远程盒子上运行,使用SAME数据库,它将登录并显示成员名称 - 但是......它不会呈现角色。任何想法为什么会这样?我的角色提供者如下所示。
using System;
using System.Linq;
using System.Collections;
using System.Collections.Generic;
namespace Providers
{
public partial class RoleProvider : System.Web.Security.RoleProvider
{
private readonly Models.Contexts.DatabaseDataContext dataContext;
protected Models.Contexts.DatabaseDataContext DataContext
{
get { return dataContext; }
}
public RoleProvider()
: base()
{
if (dataContext == null)
dataContext = new DataContextProvider().GetDataContext<Models.Contexts.DatabaseDataContext>("contextProvider");
}
public RoleProvider(IDataContextProvider dataContextProvider)
: this()
{
dataContext = dataContextProvider.GetDataContext<Models.Contexts.DatabaseDataContext>("contextProvider");
}
public override string[] GetRolesForUser(string email)
{
DataContext.Refresh(System.Data.Linq.RefreshMode.OverwriteCurrentValues);
var member = (
from m in DataContext.Users
where m.Email == email
select m).Single();
List<string> roleList = new List<string>();
foreach (Models.Group group in member.Groups)
roleList.Add(group.Role.RoleName);
return roleList.ToArray<string>();
}
}
答案 0 :(得分:2)
老实说,从查看数据库中的数据差异开始,这听起来很愚蠢,但可能角色实际上并不存在,或者ApplicationIds不同。如有必要,使用不同的数据库对应用程序运行SQL事件探查器,并验证查询是否相同,返回的数据是否相同。