HTTPClient getting two 401s before success (sending wrong token)

后端 未结 3 2027
说谎
说谎 2021-02-07 11:14

I\'m trying to communicate with a self-hosted WebAPI client using HttpClient. The client is created with the following code:

HttpClientHandler clien         


        
3条回答
  •  醉话见心
    2021-02-07 11:52

    What you are experiencing is normal, this is how the NTLM authentication scheme works.

    1: C  --> S   GET ...
    
    2: C <--  S   401 Unauthorized
                  WWW-Authenticate: NTLM
    
    3: C  --> S   GET ...
                  Authorization: NTLM 
    
    4: C <--  S   401 Unauthorized
                  WWW-Authenticate: NTLM 
    
    5: C  --> S   GET ...
                  Authorization: NTLM 
    
    6: C <--  S   200 Ok
    
    1. The client sends a GET request to the server.
    2. Since you need to be authenticated to access the requested resource, the server sends back a 401 Unathorized response and notifies the client in the WWW-Authenticate header that it supports NTLM authentication. So this is where you get your first 401 response code.
    3. The client sends the domain name and the username to the server in the Authorization header. Note that based solely on these information the client cannot be authenticated yet.
    4. The server sends a challenge to the client. It's a randomly generated number called a nonce. This is where you get your second 401 response code.
    5. The client sends back a response to the server's challenge, using its password's hash to encrypt the random number.
    6. The server sends the client's username, the challenge sent to the client and the response received from the client to the domain controller. Using the username the domain controller retrieves the hash of the user's password and encrypts the challenge with it. If the result matches the response sent by the client, the client is authenticated and the server sends back a 200 response code and the requested resource to the client.

提交回复
热议问题