Asp.net 是否获取具有特定权限的所有用户?

Asp.net 是否获取具有特定权限的所有用户?,asp.net,aspnetboilerplate,Asp.net,Aspnetboilerplate,如何获取所有具有特定权限的用户? 例如,我们需要枚举所有允许特定权限的用户。代码是这样的 var v=_userManager.GetAllUserWithSpecificPermission("ISO.Report.ReportV1"); foreach(var t in v) { Logger.Info(t.UserName); } 您需要编写查询以按权限筛选用户。这可能会指导您: var query = from user in UserManager.Users

如何获取所有具有特定权限的用户? 例如,我们需要枚举所有允许特定权限的用户。代码是这样的

var v=_userManager.GetAllUserWithSpecificPermission("ISO.Report.ReportV1");
foreach(var t in v)
{
   Logger.Info(t.UserName);
}

您需要编写查询以按权限筛选用户。这可能会指导您:

var query =     from user in UserManager.Users
                join ur in _userRoleRepository.GetAll() on user.Id equals ur.UserId into urJoined
                from ur in urJoined.DefaultIfEmpty()
                join up in _userPermissionRepository.GetAll() on new {UserId = user.Id, Name = input.Permission} equals
                new {up.UserId, up.Name} into upJoined
                from up in upJoined.DefaultIfEmpty()
                join rp in _rolePermissionRepository.GetAll() on new {RoleId = ur.RoleId, Name = input.Permission}
                equals new {rp.RoleId, rp.Name} into rpJoined
                from rp in rpJoined.DefaultIfEmpty()
                where (up != null && up.IsGranted) || (up == null && rp != null)
                group user by user
                into userGrouped
                select userGrouped.Key;

var users = await query.ToListAsync();

您需要编写查询以按权限筛选用户。这可能会指导您:

var query =     from user in UserManager.Users
                join ur in _userRoleRepository.GetAll() on user.Id equals ur.UserId into urJoined
                from ur in urJoined.DefaultIfEmpty()
                join up in _userPermissionRepository.GetAll() on new {UserId = user.Id, Name = input.Permission} equals
                new {up.UserId, up.Name} into upJoined
                from up in upJoined.DefaultIfEmpty()
                join rp in _rolePermissionRepository.GetAll() on new {RoleId = ur.RoleId, Name = input.Permission}
                equals new {rp.RoleId, rp.Name} into rpJoined
                from rp in rpJoined.DefaultIfEmpty()
                where (up != null && up.IsGranted) || (up == null && rp != null)
                group user by user
                into userGrouped
                select userGrouped.Key;

var users = await query.ToListAsync();

没有这样的方法。您应该使用存储库直接从AbpPermissions表中查询您自己(请参阅表列以了解它)@hikalkan如果您将这样的方法放到userManager或permissionManager中,它可能会很有用。感谢这个很棒的框架,没有这样的方法。您应该使用存储库直接从AbpPermissions表中查询您自己(请参阅表列以了解它)@hikalkan如果您将这样的方法放到userManager或permissionManager中,它可能会很有用。感谢这个很棒的框架