HttpClient의 인증 헤더 설정


483

REST API에 사용하는 HttpClient가 있습니다. 그러나 인증 헤더를 설정하는 데 문제가 있습니다. OAuth 요청을 통해받은 토큰으로 헤더를 설정해야합니다. 다음을 제안하는 .NET 코드가 있습니다.

httpClient.DefaultRequestHeaders.Authorization = new Credential(OAuth.token);

그러나 Credential 클래스는 WinRT에 존재하지 않습니다. 누구나 승인 헤더를 설정하는 방법에 대한 아이디어가 있습니까?


1
Credential 클래스는 어떤 네임 스페이스에 속합니까?
kampsj

@kampsj WinRT에 존재하지 않는 .NET 네임 스페이스이기 때문에 잘 모르겠습니다
Stephen Hynes

1
왜 request.Headers.Add ( "Authorization", token);
ahll April

답변:


815

이를 수행하는 방법은 다음과 같습니다.

httpClient.DefaultRequestHeaders.Authorization =
    new AuthenticationHeaderValue("Bearer", "Your Oauth token");

15
"귀하의 Oauth 토큰"은 어떻게 얻습니까?
비밀 다람쥐

3
내가 사용한 것은 client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", "encrypted user/pwd");Advanced Rest Client 크롬 확장 프로그램에서 암호화 된 사용자 / 암호를 가져옵니다.
레드

6
@Red fyi에서 두 번째 매개 변수는 base64로 인코딩 된 user : password (암호화되지 않음)입니다.
n00b

5
내 응용 프로그램은 오랫동안 행복하게 이것을 사용하고 있었고 파란색에서 RuntimeBinderException이 발생하기 시작했습니다. I가 스위치에 있었다 httpClient.DefaultRequestHeaders.Add ( "인증", "무기명", "당신의 Oauth 토큰"); 다시 시작하도록
kraeg

8
나열된 코드가 컴파일되지 않는 @kraeg는 마지막 두 문자열을 다음과 같이 연결한다는 의미입니까? client.DefaultRequestHeaders.Add ( "Authorization", "Bearer"+ "Your Oauth token");
TroySteven

354
request.DefaultRequestHeaders.Authorization = 
    new AuthenticationHeaderValue(
        "Basic", Convert.ToBase64String(
            System.Text.ASCIIEncoding.ASCII.GetBytes(
               $"{yourusername}:{yourpwd}")));

27
@MickyDuncan HttpClient에는 DefaultRequestHeaders.Authorization이 있습니다. 그리고이 답변은 내 하루를 구제했습니다. WhiteRabbit에 감사드립니다.
Joey Schluchter

3
Auhtorization 헤더를 검사하면 문자열 Basic 이상이 포함되어 있지 않으면 작동하지 않습니다.
Raffaeu

1
누구나 사용자 이름과 비밀번호를 base64 문자열로 변환하는 것이 왜 중요한지 설명 할 수 있습니까? 실제 암호화 기능을 제공하지 않는 이유는 무엇입니까?
Jonathan Wood

3
@JonathanWood 왜냐하면 그것이 사용되도록 정의 된 방법이기 때문입니다. Basic은 암호화 기능을 제공하지 않으며 헤더에서 암호 문자 선택과 관련된 문제를 피하기에 충분한 인코딩입니다.
Richard

4
ASCII 인코딩을 사용한 특별한 이유가 있습니까? 우리는 어쨌든 Base64 인코딩이기 때문에 UTF8 인코딩 사용에 문제가 없다고 가정합니다. 기본 인증 사양에 username : password 콤보가 ASCII로만 표시되어 있는지 궁금합니다.
호감

82

이 문제를 해결하는 좋은 방법을 찾고 있으며 같은 질문을보고 있습니다. 이 답변이 같은 문제를 가진 모든 사람들이 나를 좋아하도록 도울 수 있기를 바랍니다.

using (var client = new HttpClient())
{
    var url = "https://www.theidentityhub.com/{tenant}/api/identity/v1";
    client.DefaultRequestHeaders.Add("Authorization", "Bearer " + accessToken);
    var response = await client.GetStringAsync(url);
    // Parse JSON response.
    ....
}

https://www.theidentityhub.com/hub/Documentation/CallTheIdentityHubApi 에서 참조


1
나는 똑같은 일이 @willie을하고 그리고 난 여전히 내 API에서 401을 받고 있어요
SomethingOn

2
안녕하세요 @SomethingOn 나는 당신이 올바른 토큰 키를 얻지 못했다고 생각합니다 .401을 얻었습니다. 개인 "질문을하십시오"에 대한 길을 공유 할 것입니다.
Willie Cheng

14
HttpClient를 using블록 에 넣지 마십시오 . (예, 소리가 거꾸로 들리지만 usingHttpClient를 재활용하는 대신 사용하면 연결이 누출 될 수 있습니다 .)
Jonathan Allen

42

성능 및 포트 소진 문제에 대해 HttpClient 인스턴스를 재사용 하는 것이 좋습니다. 이 답변을 제공하는 답변이 없기 때문에 (그리고 나쁜 습관으로 이어질 수도 있습니다 :()) 여기에 내가 작성한 답변에 대한 링크를 넣었습니다. 비슷한 질문에 :

https://stackoverflow.com/a/40707446/717372

HttpClient를 올바르게 사용하는 방법에 대한 일부 소스 :


5
포트 고갈 문제는 농담이 아닙니다. QA에서는 거의 발생하지 않지만 프로덕션에서 많이 사용되는 프로젝트에 영향을 미칩니다.
Jonathan Allen

구체적인 예는 내 게시물을 참조하십시오 stackoverflow.com/a/59052193/790635
emp

41

TheWhiteRabbit의 답변에 동의하지만 HttpClient를 사용하여 많은 호출을하면 코드가 약간 반복적이라고 생각합니다.

나는 대답을 조금 향상시키는 두 가지 방법이 있다고 생각합니다.

클라이언트를 작성하기위한 헬퍼 클래스를 작성하십시오.

public static class ClientHelper
{
    // Basic auth
    public static HttpClient GetClient(string username,string password)
    {
            var authValue = new AuthenticationHeaderValue("Basic", Convert.ToBase64String(Encoding.UTF8.GetBytes($"{username}:{password}")));

            var client = new HttpClient(){
                DefaultRequestHeaders = { Authorization = authValue}
                //Set some other client defaults like timeout / BaseAddress
            };
            return client;
    }

    // Auth with bearer token
    public static HttpClient GetClient(string token)
    {
            var authValue = new AuthenticationHeaderValue("Bearer", token);

            var client = new HttpClient(){
                DefaultRequestHeaders = { Authorization = authValue}
                //Set some other client defaults like timeout / BaseAddress
            };
            return client;
    }
}

용법:

using(var client = ClientHelper.GetClient(username,password))
{
    //Perform some http call
}

using(var client = ClientHelper.GetClient(token))
{
    //Perform some http call
}

확장 메소드를 작성하십시오.

뷰티 상을 수상하지는 않지만 훌륭하게 작동합니다. :)

    public static class HttpClientExtentions
    {
        public static AuthenticationHeaderValue ToAuthHeaderValue(this string username, string password)
        {
            return new AuthenticationHeaderValue("Basic",
        Convert.ToBase64String(
            System.Text.Encoding.ASCII.GetBytes(
                $"{username}:{password}")));
        }
    }

용법:

using (var client = new HttpClient())
{
    client.DefaultRequestHeaders.Authorization = _username.ToAuthHeaderValue(_password); 
}

다시 한 번 위의 2 가지 옵션을 사용하면 클라이언트가 명령문을 조금 덜 반복적으로 사용할 수 있다고 생각합니다. http 호출을 여러 번 수행하는 경우 HttpClient를 재사용하는 것이 가장 좋은 방법이지만이 질문의 범위를 벗어난 것으로 생각합니다.


20
내가 당신의 대답은 upvoted되어 볼 수 있지만 난이 방법의 TL을 권장하지 것이다 DR을 자사의 일반 잘못 때문에 소켓 고갈, 여기에 설명입니다 링크
lacripta

2
@lacripta, 이것은 사실이지만 마지막 두 문장을 읽으면 HttpClient를 재사용하는 것이 가장 좋은 방법이라고 말하지만이 질문의 범위를 벗어난 것 같습니다.
Florian Schaal

1
나는 당신의 요점을 볼 수 있지만 코드가 반복적이라는 말을 제안하고 있습니다. 이 경우. 가장 많이 읽지 않는 경고 만이 아닙니다.
lacripta

1
소켓 소모 문제를 피하기 위해 HttpClientFactory를 사용하는 것이 훨씬 좋습니다.
RyanOC

21

무기명 토큰을 설정하고있었습니다

httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", token);

한 엔드 포인트에서는 작동했지만 다른 엔드 포인트에서는 작동하지 않았습니다. 문제는에 소문자가 있다는 것 b입니다 "bearer". 변경 후 이제 두 API 모두에서 작동합니다. 바늘을 찾기 위해 건초 더미 중 하나로 간주하지 않는다면 놓치기 쉬운 것입니다.

"Bearer"자본 이 있어야 합니다.


18

나는 당신에게 제안합니다 :

HttpClient.DefaultRequestHeaders.Add("Authorization", "Bearer <token>");

그런 다음 다음과 같이 사용할 수 있습니다.

var response = await client.GetAsync(url);
if (response.IsSuccessStatusCode)
{
    responseMessage = await response.Content.ReadAsAsync<ResponseMessage>();
}

예를 들어 토큰이 1 시간마다 시간 초과되면이 솔루션으로 HttpClient를 업데이트해야합니다. 귀하의 토큰이 여전히 유효한지 확인하고 그렇지 않으면 새로 고침하여 HttpRequestMessage에 추가하십시오
Johan Franzén

13

C # HttpClient를 사용하여 기본 인증을 설정합니다. 다음 코드가 나를 위해 작동합니다.

   using (var client = new HttpClient())
        {
            var webUrl ="http://localhost/saleapi/api/";
            var uri = "api/sales";
            client.BaseAddress = new Uri(webUrl);
            client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
            client.DefaultRequestHeaders.ConnectionClose = true;

            //Set Basic Auth
            var user = "username";
            var password = "password";
            var base64String =Convert.ToBase64String( Encoding.ASCII.GetBytes($"{user}:{password}"));
            client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic",base64String);

            var result = await client.PostAsJsonAsync(uri, model);
            return result;
        }

정확히 내가 필요한 것, 고마워
rchrd

9

이것이 내가 한 방법입니다.

using (HttpClient httpClient = new HttpClient())
{
   Dictionary<string, string> tokenDetails = null;
   var messageDetails = new Message { Id = 4, Message1 = des };
   HttpClient client = new HttpClient();
   client.BaseAddress = new Uri("http://localhost:3774/");
   var login = new Dictionary<string, string>
       {
           {"grant_type", "password"},
           {"username", "sa@role.com"},
           {"password", "lopzwsx@23"},
       };
   var response = client.PostAsync("Token", new FormUrlEncodedContent(login)).Result;
   if (response.IsSuccessStatusCode)
   {
      tokenDetails = JsonConvert.DeserializeObject<Dictionary<string, string>>(response.Content.ReadAsStringAsync().Result);
      if (tokenDetails != null && tokenDetails.Any())
      {
         var tokenNo = tokenDetails.FirstOrDefault().Value;
         client.DefaultRequestHeaders.Add("Authorization", "Bearer " + tokenNo);
         client.PostAsJsonAsync("api/menu", messageDetails)
             .ContinueWith((postTask) => postTask.Result.EnsureSuccessStatusCode());
      }
   }
}

이 유튜브 비디오는 많은 도움이됩니다. 그것을 확인하시기 바랍니다. https://www.youtube.com/watch?v=qCwnU06NV5Q


9

기본 권한 및 Json 매개 변수를 사용하십시오.

using (HttpClient client = new HttpClient())
                    {
                        var request_json = "your json string";

                        var content = new StringContent(request_json, Encoding.UTF8, "application/json");

                        var authenticationBytes = Encoding.ASCII.GetBytes("YourUsername:YourPassword");

                        client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic",
                               Convert.ToBase64String(authenticationBytes));
                        client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));

                        var result = await client.PostAsync("YourURL", content);

                        var result_string = await result.Content.ReadAsStringAsync();
                    }

2
이와 같은 예제에서 SSL 인증서 확인을 비활성화하는 코드를 포함해서는 안됩니다. 사람들은 맹목적으로 코드를 복사하지 않고 코드를 복사 할 수 있습니다. 나는 당신을 위해 그 줄을 제거했습니다.
John

9

을 다시 HttpClient사용하려면을 사용하지 않는 것이 좋습니다.DefaultRequestHeaders 각 요청과 함께 전송하는 데 .

당신은 이것을 시도 할 수 있습니다 :

var requestMessage = new HttpRequestMessage
    {
        Method = HttpMethod.Post,
        Content = new StringContent("...", Encoding.UTF8, "application/json"),
        RequestUri = new Uri("...")
    };

requestMessage.Headers.Authorization = new AuthenticationHeaderValue("Basic", 
    Convert.ToBase64String(System.Text.ASCIIEncoding.ASCII.GetBytes($"{user}:{password}")));

var response = await _httpClient.SendAsync(requestMessage);

8

6 년 후 누군가를 도울 수 있도록 이것을 추가하십시오.

https://www.codeproject.com/Tips/996401/Authenticate-WebAPIs-with-Basic-and-Windows-Authen

var authenticationBytes = Encoding.ASCII.GetBytes("<username>:<password>");
using (HttpClient confClient = new HttpClient())
{
  confClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", 
         Convert.ToBase64String(authenticationBytes));
  confClient.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue(Constants.MediaType));  
  HttpResponseMessage message = confClient.GetAsync("<service URI>").Result;
  if (message.IsSuccessStatusCode)
  {
    var inter = message.Content.ReadAsStringAsync();
    List<string> result = JsonConvert.DeserializeObject<List<string>>(inter.Result);
  }
}

나를 위해 일했다. 나를 위해 효과가 없었던 Willie Cheng의 대답과는 반대로.
user890332

5

UTF8 옵션

request.DefaultRequestHeaders.Authorization = 
new AuthenticationHeaderValue(
    "Basic", Convert.ToBase64String(
        System.Text.Encoding.UTF8.GetBytes(
           $"{yourusername}:{yourpwd}")));

3

어셈블리 AuthenticationHeaderValue클래스 사용System.Net.Http

public AuthenticationHeaderValue(
    string scheme,
    string parameter
)

다음 과 같이 기존 Authorization헤더를 설정하거나 업데이트 할 수 있습니다 httpclient.

httpclient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", TokenResponse.AccessToken);

1
SO에 오신 것을 환영하지만 컨텍스트를 더 추가하십시오.
JP Hellemons

정답은 제자리에 있지만 그의 코드가 무엇을 해야하는지 설명하는 한 개의 라이너가있는 것은 아프지 않습니다. 그냥 말하면
iiminov

2

BaseWebApi.cs

public abstract class BaseWebApi
{
    //Inject HttpClient from Ninject
    private readonly HttpClient _httpClient;
    public BaseWebApi(HttpClient httpclient)
    {
        _httpClient = httpClient;
    }

    public async Task<TOut> PostAsync<TOut>(string method, object param, Dictionary<string, string> headers, HttpMethod httpMethod)
    {
        //Set url

        HttpResponseMessage response;
        using (var request = new HttpRequestMessage(httpMethod, url))
        {
            AddBody(param, request);
            AddHeaders(request, headers);
            response = await _httpClient.SendAsync(request, cancellationToken);
        }

        if(response.IsSuccessStatusCode)
        {
             return await response.Content.ReadAsAsync<TOut>();
        }
        //Exception handling
    }

    private void AddHeaders(HttpRequestMessage request, Dictionary<string, string> headers)
    {
        request.Headers.Accept.Clear();
        request.Headers.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));

        if (headers == null) return;

        foreach (var header in headers)
        {
            request.Headers.Add(header.Key, header.Value);
        }
    }

    private static void AddBody(object param, HttpRequestMessage request)
    {
        if (param != null)
        {
            var content = JsonConvert.SerializeObject(param);
            request.Content = new StringContent(content);
            request.Content.Headers.ContentType = new MediaTypeHeaderValue("application/json");
        }
    }

SubWebApi.cs

public sealed class SubWebApi : BaseWebApi
{
    public SubWebApi(HttpClient httpClient) : base(httpClient) {}

    public async Task<StuffResponse> GetStuffAsync(int cvr)
    {
        var method = "get/stuff";
        var request = new StuffRequest 
        {
            query = "GiveMeStuff"
        }
        return await PostAsync<StuffResponse>(method, request, GetHeaders(), HttpMethod.Post);
    }
    private Dictionary<string, string> GetHeaders()
    {
        var headers = new Dictionary<string, string>();
        var basicAuth = GetBasicAuth();
        headers.Add("Authorization", basicAuth);
        return headers;
    }

    private string GetBasicAuth()
    {
        var byteArray = Encoding.ASCII.GetBytes($"{SystemSettings.Username}:{SystemSettings.Password}");
        var authString = Convert.ToBase64String(byteArray);
        return $"Basic {authString}";
    }
}

1

HttpClientBearer Token으로 요청 을 보내려 는 경우이 코드는 좋은 해결책이 될 수 있습니다.

var requestMessage = new HttpRequestMessage
{
    Method = HttpMethod.Post,
    Content = new StringContent(".....", Encoding.UTF8, "application/json"),
    RequestUri = new Uri(".....")
};

requestMessage.Headers.Authorization = new AuthenticationHeaderValue("Bearer", "Your token");

var response = await _httpClient.SendAsync(requestMessage);

0

net .core에서 사용할 수 있습니다

var client = new HttpClient();
client.SetBasicAuthentication(userName, password);

또는

var client = new HttpClient();
client.SetBearerToken(token);

1
첫 번째 예제는 SetBasicAuthentication()기본적으로 사용할 수 없으므로 작동하지 않으므로 확장 방법이어야합니다. 어디에 정의되어 있습니까?
ViRuSTriNiTy

0

기존 라이브러리를 사용하는 것이 더 쉬울 수 있습니다.

예를 들어 아래 확장 방법은 Identity Server 4 https://www.nuget.org/packages/IdentityModel/에 추가됩니다.

 public static void SetBasicAuthentication(this HttpClient client, string userName, string password);
    //
    // Summary:
    //     Sets a basic authentication header.
    //
    // Parameters:
    //   request:
    //     The HTTP request message.
    //
    //   userName:
    //     Name of the user.
    //
    //   password:
    //     The password.
    public static void SetBasicAuthentication(this HttpRequestMessage request, string userName, string password);
    //
    // Summary:
    //     Sets a basic authentication header for RFC6749 client authentication.
    //
    // Parameters:
    //   client:
    //     The client.
    //
    //   userName:
    //     Name of the user.
    //
    //   password:
    //     The password.
    public static void SetBasicAuthenticationOAuth(this HttpClient client, string userName, string password);
    //
    // Summary:
    //     Sets a basic authentication header for RFC6749 client authentication.
    //
    // Parameters:
    //   request:
    //     The HTTP request message.
    //
    //   userName:
    //     Name of the user.
    //
    //   password:
    //     The password.
    public static void SetBasicAuthenticationOAuth(this HttpRequestMessage request, string userName, string password);
    //
    // Summary:
    //     Sets an authorization header with a bearer token.
    //
    // Parameters:
    //   client:
    //     The client.
    //
    //   token:
    //     The token.
    public static void SetBearerToken(this HttpClient client, string token);
    //
    // Summary:
    //     Sets an authorization header with a bearer token.
    //
    // Parameters:
    //   request:
    //     The HTTP request message.
    //
    //   token:
    //     The token.
    public static void SetBearerToken(this HttpRequestMessage request, string token);
    //
    // Summary:
    //     Sets an authorization header with a given scheme and value.
    //
    // Parameters:
    //   client:
    //     The client.
    //
    //   scheme:
    //     The scheme.
    //
    //   token:
    //     The token.
    public static void SetToken(this HttpClient client, string scheme, string token);
    //
    // Summary:
    //     Sets an authorization header with a given scheme and value.
    //
    // Parameters:
    //   request:
    //     The HTTP request message.
    //
    //   scheme:
    //     The scheme.
    //
    //   token:
    //     The token.
    public static void SetToken(this HttpRequestMessage request, string scheme, string token);

0

Oauth 프로세스 흐름은 복잡하며 항상 오류가 발생할 여지가 있습니다. OAuth 인증 흐름을 위해 상용구 코드와 라이브러리 세트를 항상 사용하는 것이 좋습니다.

다음은 라이브러리 세트에 대한 링크입니다. .Net 용 OAuth 라이브러리


-1

서비스에서 json 또는 xml을 수신하는 경우 작동 할 수 있으며 MakeXmlRequest (put results in xmldocumnet) 및 MakeJsonRequest 함수를 사용하면 헤더 및 T 유형의 작동 방식에 대한 아이디어를 얻을 수 있다고 생각합니다. 다음 방법으로 (원하는 클래스에 json을 응답하여 동일한 구조를 갖는 json을 넣으십시오)

/*-------------------------example of use-------------*/
MakeXmlRequest<XmlDocument>("your_uri",result=>your_xmlDocument_variable =     result,error=>your_exception_Var = error);

MakeJsonRequest<classwhateveryouwant>("your_uri",result=>your_classwhateveryouwant_variable=result,error=>your_exception_Var=error)
/*-------------------------------------------------------------------------------*/


public class RestService
{
    public void MakeXmlRequest<T>(string uri, Action<XmlDocument> successAction, Action<Exception> errorAction)
    {
        XmlDocument XMLResponse = new XmlDocument();
        string wufooAPIKey = ""; /*or username as well*/
        string password = "";
        StringBuilder url = new StringBuilder();
        url.Append(uri);
        HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(url.ToString());
        string authInfo = wufooAPIKey + ":" + password;
        authInfo = Convert.ToBase64String(Encoding.Default.GetBytes(authInfo));
        request.Timeout = 30000;
        request.KeepAlive = false;
        request.Headers["Authorization"] = "Basic " + authInfo;
        string documento = "";
        MakeRequest(request,response=> documento = response,
                            (error) =>
                            {
                             if (errorAction != null)
                             {
                                errorAction(error);
                             }
                            }
                   );
        XMLResponse.LoadXml(documento);
        successAction(XMLResponse);
    }



    public void MakeJsonRequest<T>(string uri, Action<T> successAction, Action<Exception> errorAction)
    {
        string wufooAPIKey = "";
        string password = "";
        StringBuilder url = new StringBuilder();
        url.Append(uri);
        HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(url.ToString());
        string authInfo = wufooAPIKey + ":" + password;
        authInfo = Convert.ToBase64String(Encoding.Default.GetBytes(authInfo));
        request.Timeout = 30000;
        request.KeepAlive = false;
        request.Headers["Authorization"] = "Basic " + authInfo;
       // request.Accept = "application/json";
      //  request.Method = "GET";
        MakeRequest(
           request,
           (response) =>
           {
               if (successAction != null)
               {
                   T toReturn;
                   try
                   {
                       toReturn = Deserialize<T>(response);
                   }
                   catch (Exception ex)
                   {
                       errorAction(ex);
                       return;
                   }
                   successAction(toReturn);
               }
           },
           (error) =>
           {
               if (errorAction != null)
               {
                   errorAction(error);
               }
           }
        );
    }
    private void MakeRequest(HttpWebRequest request, Action<string> successAction, Action<Exception> errorAction)
    {
        try{
            using (var webResponse = (HttpWebResponse)request.GetResponse())
            {
                using (var reader = new StreamReader(webResponse.GetResponseStream()))
                {
                    var objText = reader.ReadToEnd();
                    successAction(objText);
                }
            }
        }catch(HttpException ex){
            errorAction(ex);
        }
    }
    private T Deserialize<T>(string responseBody)
    {
        try
        {
            var toReturns = JsonConvert.DeserializeObject<T>(responseBody);
             return toReturns;
        }
        catch (Exception ex)
        {
            string errores;
            errores = ex.Message;
        }
        var toReturn = JsonConvert.DeserializeObject<T>(responseBody);
        return toReturn;
    }
}
}

-1
static async Task<AccessToken> GetToken()
{
        string clientId = "XXX";
        string clientSecret = "YYY";
        string credentials = String.Format("{0}:{1}", clientId, clientSecret);

        using (var client = new HttpClient())
        {
            client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", Convert.ToBase64String(Encoding.UTF8.GetBytes(credentials)));
            List<KeyValuePair<string, string>> requestData = new List<KeyValuePair<string, string>>();
            requestData.Add(new KeyValuePair<string, string>("grant_type", "client_credentials"));
            FormUrlEncodedContent requestBody = new FormUrlEncodedContent(requestData);
            var request = await client.PostAsync("https://accounts.spotify.com/api/token", requestBody);
            var response = await request.Content.ReadAsStringAsync();
            return JsonConvert.DeserializeObject<AccessToken>(response);
        }
    }

stackoverflow에 오신 것을 환영합니다. 제공 한 답변 외에도 문제가 해결되는 이유와 방법에 대한 간단한 설명을 제공하십시오.
jtate

-2

헤더 설정에 도움이 될 수 있습니다.

WebClient client = new WebClient();

string authInfo = this.credentials.UserName + ":" + this.credentials.Password;
authInfo = Convert.ToBase64String(Encoding.Default.GetBytes(authInfo));
client.Headers["Authorization"] = "Basic " + authInfo;

9
그는 HttpClient아닌을 사용 하고 WebClient있습니다.
Jean Hominal
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.