-1

我的 EF 使用存储库 + unti od 工作模式有一个奇怪的行为。

问题是,当我创建一个用户并为他分配一个角色时,重定向到目标页面需要一个特定的角色,所以在我的 RoleProvider 中我覆盖了 GetRolesForUser :

public override string[] GetRolesForUser(string username)
{

    string[] listRoles = unitOfWork.RoleRepository.Find(r => r.Utilisateurs.Any(u => u.Login == username)).ToList().Select(r => r.Nom).ToArray<string>();



    return listRoles;
}

此时数据库中的用户已经创建,但他没有出现在他的角色中。

我将我的代码更改为这个新版本:

public override string[] GetRolesForUser(string username)
{
    string[] listRoles;

    Utilisateur user = unitOfWork.UtilisateurRepository.Find(u => u.Login == username).FirstOrDefault();

    if (user != null)
        listRoles = user.Roles.Select(r => r.Nom).ToList().ToArray();
    else
    {
        listRoles = new string[1];
        listRoles[0] = "";
    }


    return listRoles;
}

对于信息,我根据请求使用一个工作单元。

在 MembershipProvider 和 RoleProvider 类中,我使用:

private IUnitOfWork unitOfWork = new UnitOfWork();

在我的 DAl 中,我使用了一个通用存储库:

public class GenericRepository<T> : IRepository<T> where T : class
{
    internal DVEntities context;
    internal IDbSet<T> dbset;


    public GenericRepository(DVEntities context)
    {
        this.context = context;
        this.dbset = context.Set<T>();
    }
    public IUnitOfWork UnitOfWork
    {
        get;
        set;
    }

    public IQueryable<T> All()
    {
        return dbset.AsQueryable();
    }

    //public IQueryable<T> Find(Func<T, bool> expression)
    public IQueryable<T> Find(Func<T, bool> expression)
    {
        return dbset.Where(expression).AsQueryable();
    }

    public void Add(T entity)
    {
        dbset.Add(entity);
    }

    public void Attach(T entity)
    {
        dbset.Attach(entity);
    }

    public void Detach(T entity)
    {
        ((IObjectContextAdapter)context).ObjectContext.Detach(entity);            
    }

    public void Delete(T entity)
    {
        if (context.Entry(entity).State == EntityState.Detached)
        {
            dbset.Attach(entity);
        }
        dbset.Remove(entity);
    }

    public void Update(T entityToUpdate)
    {
        dbset.Attach(entityToUpdate);
        //dbset.Add(entityToUpdate);

        context.Entry(entityToUpdate).State = EntityState.Modified;
    }

    public void Save()
    {
        context.SaveChanges();
    }
}

谁能解释一下这个问题?

谢谢。

4

1 回答 1

0

您的存储库应采用Expression<Func<T, bool>>as 参数,而不是Func<T, bool>

public IQueryable<T> Find(Expresssion<Func<T, bool>> expression)

然后你的第一个版本使用...

public override string[] GetRolesForUser(string username)
{
    string[] listRoles = unitOfWork.RoleRepository
        .Find(r => r.Utilisateurs.Any(u => u.Login == username))
        .Select(r => r.Nom)
        .ToArray();

    return listRoles;
}

... 应该管用。

于 2013-04-15T00:40:58.927 回答