У меня есть приложение ASP.NET Core 8.0 MVC, работающее на IIS 10 и использующее аутентификацию cookie. Я заметил, что IIS не включает имя пользователя в журнал после аутентификации пользователя. Регистрация имени пользователя в журнале IIS включена.
Это приложение было преобразовано из приложения ASP.NET MVC и веб-форм. Раньше пользователи аутентифицировались с помощью форм, и IIS регистрировал имя пользователя в каждом запросе (после аутентификации пользователя).
Есть идеи, как заставить IIS регистрировать имя пользователя в контексте приложения ASP.NET Core, которое использует проверку подлинности с помощью файлов cookie?
ТИА
Обновлено: Другой способ сделать это - использовать:
но тогда часть журналов будет дублироваться, поскольку ведение журнала IIS включено (по соображениям политики).
Если я не найду ответа, я воспользуюсь W3CLogger.
Согласно этой проблеме, вы можете обнаружить, что по умолчанию имя пользователя cs не добавляется.
Поэтому, если вы хотите зарегистрировать имя пользователя, вам следует использовать настраиваемое поле для журналов IIS.
Вы можете добавить приведенные ниже коды в файл program.cs:
app.Use(async (context, next) =>
{
if (context.User.Identity.IsAuthenticated && context.Features.Get<IServerVariablesFeature>() is IServerVariablesFeature serverVariables)
{
serverVariables["AUTH_USER"] = context.User.Identity.Name ?? "?";
}
await next.Invoke();
});
Затем вы можете изменить IIS w3wc, добавив настраиваемое поле. как показано ниже:
Результат:
Спасибо, я попробую. Я предполагаю, что вызов Use должен быть выполнен после UseAuthorization.