Существует многоуровневое решение поставщика ролей Microsoft, которое позволяет кэшировать роли пользователя в файле cookie, поэтому нет необходимости вызывать метод GetRolesForUser провайдера.Я считаю, что кэширование файлов cookie является частью класса Roles, поэтому, пока вы реализуете из базового класса RoleProvider, оно должно быть совместимым.Стоит взглянуть на код в рефлекторе, чтобы понять, как MS реализует свои собственные абстрактные классы и что делают статические вспомогательные классы (роли и членство)
Попробуйте добавить cacheRolesInCookie = "true" в roleManager.элемент в файле конфигурации и посмотрите, изменится ли поток.
Поскольку вы используете собственную реализацию RoleProvider, вы также можете переопределить метод IsUserInRole и предоставить собственную реализацию проверки, находится ли пользователь вроль.
ОБНОВЛЕНИЕ: Этот блок кода вызывается внутри метода Roles.IsUserInRole:
IPrincipal currentUser = GetCurrentUser();
if (((currentUser != null) && (currentUser is RolePrincipal)) && ((((RolePrincipal) currentUser).ProviderName == Provider.Name) && StringUtil.EqualsIgnoreCase(username, currentUser.Identity.Name)))
{
flag = currentUser.IsInRole(roleName);
}
else
{
flag = Provider.IsUserInRole(username, roleName);
}
Блок else - это то, что будет вызывать IsUserInRole вашего пользовательского провайдера.method.
Таким образом, роли вашего пользователя еще не добавлены в объект Principal.Если вы просто еще не дошли до этого шага, хорошо.Если нет, убедитесь, что вы делаете это.Он будет гарантировать, что каждый раз, когда вы вызываете Roles.IsUserInRole или User.IsInRole, эти функции будут использовать кэш в памяти ролей для пользователя (после загрузки) вместо того, чтобы каждый раз обращаться к базе данных.(Хотя поставщик основной роли и класс менеджера ролей должны позаботиться об этом за вас.)
Можете ли вы проверить параметры файла конфигурации для поставщика роли?Кроме того, какую версию .net вы используете?Вы вручную управляете процессом входа в систему или используете контроль входа в систему .net?Вы реализовали собственный класс ролей?Или вы используете System.Web.Security.Roles?