CookieContainer.Add(uri, cookie)
isteğe önce bir istek çerez eklemek çerez kabı doldurmak için:
private async Task<string> Login(string username, string password)
{
try
{
string url = "http://app.agelessemail.com/account/login/";
Uri address = new Uri(url);
var postData = new List<KeyValuePair<string, string>>
{
new KeyValuePair<string, string>("username", username),
new KeyValuePair<string, string>("password ", password)
};
HttpContent content = new FormUrlEncodedContent(postData);
var cookieJar = new CookieContainer();
var handler = new HttpClientHandler
{
CookieContainer = cookieJar,
UseCookies = true,
UseDefaultCredentials = false
};
var client = new HttpClient(handler)
{
BaseAddress = address
};
HttpResponseMessage response = await client.PostAsync(url,content);
response.EnsureSuccessStatusCode();
string body = await response.Content.ReadAsStringAsync();
return body;
}
catch (Exception e)
{
return e.ToString();
}
}
İşte tam cevaptır. İstek yapıldıktan sonra çerez kutusu otomatik olarak cevabın tüm çerezleri ile doldurulur. Daha sonra onları geri almak için GetCookies() öğesini arayabilirsiniz.
CookieContainer cookies = new CookieContainer();
HttpClientHandler handler = new HttpClientHandler();
handler.CookieContainer = cookies;
HttpClient client = new HttpClient(handler);
HttpResponseMessage response = client.GetAsync("http://google.com").Result;
Uri uri = new Uri("http://google.com");
IEnumerable<Cookie> responseCookies = cookies.GetCookies(uri).Cast<Cookie>();
foreach (Cookie cookie in responseCookies)
Console.WriteLine(cookie.Name + ": " + cookie.Value);
Console.ReadLine();
Merak etme, neden istemcideki çerezleri okumak istediğinizi sorabilir miyim? Anlayışım, çerezlerin bilgi vermek için değil, sunucuya bilgi göndermek için kullanılmalarıdır. –
İade edilen çerezi, JSON'a geri dönen aramalarda kullanırım, böylece her JSON araması için ayrı bir yetkilendirme çağrısı yapmak zorunda kalmam. Yani JSON'u döndüren ancak yalnızca yetkilendirilmiş bir çağrı günlüğü/Home/GetData'm var. Müşteri isteğinde,/Home/GetData'nın yanıt vermesi için çerezi ekledim. Aksi takdirde "403" yetkisiz olarak söylenir. –
Yetkilendirme üstbilgisini varsayılan başlık olarak ayarlamak neredeyse etkili ve biraz daha standarttır. Sunucunun auth başlığını otomatik olarak istemci adına ayarlaması için bir yol yoktur. –