奇怪的角色提供者行为

时间:2010-01-15 16:03:18

标签: asp.net-mvc asp.net-membership

我使用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>();
        }
}

1 个答案:

答案 0 :(得分:2)

老实说,从查看数据库中的数据差异开始,这听起来很愚蠢,但可能角色实际上并不存在,或者ApplicationIds不同。如有必要,使用不同的数据库对应用程序运行SQL事件探查器,并验证查询是否相同,返回的数据是否相同。