我的 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();
}
}
谁能解释一下这个问题?
谢谢。