ASP.NETCore:使用身份验证登录时指定控制器名称的日志记录
创始人
2024-09-18 18:30:46
0

要记录使用 ASP.NET Core Identity 进行登录的日志,我们可以使用自定义的 ApplicationSignInManager ,然后在 LoginAsync 方法中使用 ILogger 进行记录。但是,如果我们要记录日志后,希望在控制台中显示控制器名称,以便更好地跟踪用户流,我们需要指定控制器名称。

以下是指定控制器名称的示例代码:

public class ApplicationSignInManager : SignInManager
{
    private readonly ILogger _logger;

    public ApplicationSignInManager(UserManager userManager,
        IHttpContextAccessor contextAccessor,
        IUserClaimsPrincipalFactory claimsFactory,
        IOptions optionsAccessor,
        ILogger logger) : base(userManager,
            contextAccessor, claimsFactory, optionsAccessor)
    {
        _logger = logger;
    }

    public override async Task PasswordSignInAsync(string userName,
        string password,
        bool isPersistent,
        bool lockoutOnFailure)
    {
        // Retrieve controller and action name from HttpContext
        string controllerName = Context.Request.Path.Value
            .Split('/', StringSplitOptions.RemoveEmptyEntries).FirstOrDefault();
        string actionName = Context.Request.Query["ActionName"];

        // Log the sign in attempt including the controller and action name
        _logger.LogInformation($"Signing in {userName} with controller '{controllerName}' and action '{actionName}'");
        var result = await base.PasswordSignInAsync(userName, password, isPersistent, lockoutOnFailure);
        if (result.Succeeded)
        {
            // Log the successful sign in including the controller and action name
            _logger.LogInformation($"User {userName} with controller '{controllerName}' and action '{actionName}' logged in.");
        }
        else
        {
            // Log the failed sign in attempt including the controller and action name
            _logger.LogInformation($"Failed sign in attempt for {userName} with controller '{controllerName}' and action '{actionName}'");
        }

        return result;
    }
}

在上面的代码中,我们在 PasswordSignInAsync 方法中检索了控制器名称和操作名称,并在日志记录语句中使用它们。然后,我们使用重写的方法调用基类的 PasswordSignInAsync 方法以进行身份验证并返回结果。如果身份验证成功,我们记录日志以指示成功的登录。否则,我们记录日志以指示失败的登录尝试。

要确保我们能够在控制台中看到控制

相关内容

热门资讯

关于透视"wpk正版... >>>您好:,软件加微信【添加136704302】确实是有挂的,很多玩家在这款游戏中打牌都会发现很多...
曝光透视"WePoK... 您好,WePoKer透视软件怎么用这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302...
教会透视"wepok... 您好:wepoker透视底牌脚本这款游戏是可以开挂的,软件加【添加微信客服136704302】确实是...
原来有透视"wepO... wepOKer能透视吗是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以...
实测透视"微扑克的辅... 实测透视"微扑克的辅助工具有哪些"开挂(透视)辅助平台(盘点一款透牌教程)是一款可以让一直输的玩家,...
详细透视"wepok... wepoker技巧攻略是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以...
详细透视"微扑克辅助... 您好:微扑克辅助封号这款游戏是可以开挂的,软件加【添加微信客服136704302】确实是有挂的,很多...
分享透视"wpk有挂... wpk有挂吗是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我微信客...
分享透视"wepok... 分享透视"wepoker原来有挂"开挂(透视)辅助脚本(重大通报新版2026教程)是一款可以让一直输...
科技透视"wepok... >>您好:wepoker机制发冤家牌软件加扣扣群确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用...