J'essaie de faire la boucle suivante (qui fonctionne pour moi) en C # en utilisant HttpClient.
curl -X POST http://www.somehosturl.com \
-u <client-id>:<client-secret> \
-d 'grant_type=password' \
-d 'username=<email>' \
-d 'password=<password>' \
-d 'scope=all
Le code C #:
HttpClientHandler handler = new HttpClientHandler { Credentials = new
System.Net.NetworkCredential ("my_client_id", "my_client_secret")
};
try
{
using(var httpClient = new HttpClient(handler))
{
var activationUrl = "www.somehosturl.com";
var postData = "grant_type=password&[email protected]&password=mypass&scope=all";
var content = new StringContent(postData, Encoding.UTF8, "application/x-www-form-urlencoded");
var response = await httpClient.PostAsync(activationUrl, content);
if(!response.IsSuccessStatusCode)
return null;
var result = await response.Content.ReadAsStringAsync();
return result;
}
}
catch(Exception)
{
return null;
}
Lorsqu'il est exécuté, se bloque simplement, ne détecte même pas l'exception
Normalement, je suis en mesure d'obtenir et POST parfaitement bien, mais ce qui me dérange, c'est comment définir les informations d'authentification (client-id et client-secret)
Vous devez d'abord définir l'en-tête Authorization
- avec votre <clientid>
et <clientsecret>
.
Au lieu d'utiliser StringContent
, vous devez utiliser FormUrlEncodedContent
comme indiqué ci-dessous:
var client = new HttpClient();
client.BaseAddress = new Uri("http://myserver");
var request = new HttpRequestMessage(HttpMethod.Post, "/path");
var byteArray = new UTF8Encoding().GetBytes("<clientid>:<clientsecret>");
client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", Convert.ToBase64String(byteArray));
var formData = new List<KeyValuePair<string, string>>();
formData.Add(new KeyValuePair<string, string>("grant_type", "password"));
formData.Add(new KeyValuePair<string, string>("username", "<email>"));
formData.Add(new KeyValuePair<string, string>("password", "<password>"));
formData.Add(new KeyValuePair<string, string>("scope", "all"));
request.Content = new FormUrlEncodedContent(formData);
var response = await client.SendAsync(request);
Essayez de placer vos informations d'identification directement dans la propriété headers de HttpClient.
using (var client = new HttpClient()) {
var byteArray = Encoding.ASCII.GetBytes("my_client_id:my_client_secret");
var header = new AuthenticationHeaderValue("Basic",Convert.ToBase64String(byteArray));
client.DefaultRequestHeaders.Authorization = header;
return await client.GetStringAsync(uri);
}