Search code examples
c#asp.netasp.net-coreaccess-token

Check if user is logged in with Token Based Authentication in ASP.NET Core


I managed to implement this token based authentication system in my application, but I have a little question. How can I check if a user is signed it (eg if the there is a valid token in the request) within the method? So with the [Authorize] ?

So I have controller, and in that controller I want to check if the user is signed in. I thought of using this:

if (_signInManager.IsSignedIn(ClaimsPrincipal.Current))
{
    ...
}

but it does not work since ClaimsPrincipal.Current is always null


Solution

  • You don't need to use the SigninManager or something similar. The user is injected on the pipeline (on the User property of the base controller) and it's info is filled automatically by the authentication middleware (cookie or token). So, on your controller:

    bool isAuthenticated = User.Identity.IsAuthenticated;