IdentityServer 4, OpenIdConnect redirect to external sign-in url

后端 未结 1 930
无人及你
无人及你 2021-02-03 11:43

I am trying to build multiple small ASP.Net core Mvc services that connect to a Identity server built using IdentityServer4.

I have setup the OpenIdOption on the MVC se

1条回答
  •  春和景丽
    2021-02-03 12:12

    You seem to misunderstand what that /signin-oidc route is for. The general flow works like this:

    1. User visits the ASP.NET Core site.
    2. App asks the default authentication scheme, "Cookies", to authenticate.
      1. The cookie authentication handler attempts to restore the identity from the (signed) cookie information.
      2. Cookie authentication fails because cookie is missing.
    3. App asks the default challenge scheme, "oidc", to perform an authentication challenge.
      1. OpenIdConnect authentication handler redirects to the OpenId Connect authentication provider, this is your Identity Server.
      2. User logs in successfully on the Identity Server.
      3. User is POSTed to /signin-oidc which is the remote sign-in address for the OpenId Connect authentication handler.
      4. OpenId Connect authentication middleware handles the /signin-oidc route and retrieves the user information from the sign-in request that was made by Identity Server.
      5. OpenId Connect authentication scheme creates the authentication ticket and asks the configured sign-in scheme to sign in the user.
    4. Cookie authentication scheme handles the sign-in process and creates the user identity. It stores the identity in a cookie, so it can be retrieved on future requests without having to go through the whole authentication challenge pipeline again.
    5. User is signed in.

    So the /signin-oidc endpoint is the way to return back to your application to complete the sign-in process of the OpenId Connect authentication flow. By the time the user reaches this address, they have already signed in on the Identity Server and they are being redirected back to the application to continue where they originally left off.

    Usually, the time the user spends on that route is minimal since it will redirect back into a “proper” application route immediately after the sign-in request has been processed.

    So no, there will be no login form here. The login process itself is the responsibility of your OpenId Connect authentication provider, your Identity Server. That’s the whole point about this, so you e.g. login securely on google.com with your Google credentials instead of on my-random-and-probably-untrusted-app.example.com which definitely should not get hold of your actual Google credentials.

    0 讨论(0)
提交回复
热议问题