web-dev-qa-db-ja.com

HttpClient HttpRequestMessageでCookieを設定する方法

Web APIのHttpClientを使用して、アカウントを識別するHTTP Cookieの形式でログインを必要とするエンドポイントへの投稿を試みています(これは#ifdef 'edリリースバージョン)。

HttpRequestMessageにCookieを追加するにはどうすればよいですか?

212
George Mauer

リクエストにカスタムcookie値を設定する方法は次のとおりです。

var baseAddress = new Uri("http://example.com");
var cookieContainer = new CookieContainer();
using (var handler = new HttpClientHandler() { CookieContainer = cookieContainer })
using (var client = new HttpClient(handler) { BaseAddress = baseAddress })
{
    var content = new FormUrlEncodedContent(new[]
    {
        new KeyValuePair<string, string>("foo", "bar"),
        new KeyValuePair<string, string>("baz", "bazinga"),
    });
    cookieContainer.Add(baseAddress, new Cookie("CookieName", "cookie_value"));
    var result = client.PostAsync("/test", content).Result;
    result.EnsureSuccessStatusCode();
}
311
Darin Dimitrov

受け入れられた答え はほとんどの場合これをする正しい方法です。ただし、cookieヘッダーを手動で設定したい場合がいくつかあります。通常、 "Cookie"ヘッダーを設定しても無視されますが、HttpClientHandlerはデフォルトでCookieにCookieContainerプロパティを使用するためです。これを無効にした場合は、UseCookiesfalseに設定することでCookieヘッダーを手動で設定でき、それらはリクエストに表示されます。

var baseAddress = new Uri("http://example.com");
using (var handler = new HttpClientHandler { UseCookies = false })
using (var client = new HttpClient(handler) { BaseAddress = baseAddress })
{
    var message = new HttpRequestMessage(HttpMethod.Get, "/test");
    message.Headers.Add("Cookie", "cookie1=value1; cookie2=value2");
    var result = await client.SendAsync(message);
    result.EnsureSuccessStatusCode();
}
278
Greg Beech

この問題に何時間も費やした後、上記の答えはどれも私を助けてくれなかったので、私は本当に便利なツールを見つけました。

最初に、私はTelerikのFiddler 4を使って私のWebリクエストを詳細に調べました。

第二に、私はFiddlerのためのこの便利なプラグインに出会いました:

https://github.com/sunilpottumuttu/FiddlerGenerateHttpClientCode

それはあなたのためにC#コードを生成するだけです。例は次のとおりです。

        var uriBuilder = new UriBuilder("test.php", "test");
        var httpClient = new HttpClient();


        var httpRequestMessage = new HttpRequestMessage(HttpMethod.Post, uriBuilder.ToString());



        httpRequestMessage.Headers.Add("Host", "test.com");
        httpRequestMessage.Headers.Add("Connection", "keep-alive");
     //   httpRequestMessage.Headers.Add("Content-Length", "138");
        httpRequestMessage.Headers.Add("Pragma", "no-cache");
        httpRequestMessage.Headers.Add("Cache-Control", "no-cache");
        httpRequestMessage.Headers.Add("Origin", "test.com");
        httpRequestMessage.Headers.Add("Upgrade-Insecure-Requests", "1");
    //    httpRequestMessage.Headers.Add("Content-Type", "application/x-www-form-urlencoded");
        httpRequestMessage.Headers.Add("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36");
        httpRequestMessage.Headers.Add("Accept", "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8");
        httpRequestMessage.Headers.Add("Referer", "http://www.translationdirectory.com/");
        httpRequestMessage.Headers.Add("Accept-Encoding", "gzip, deflate");
        httpRequestMessage.Headers.Add("Accept-Language", "en-GB,en-US;q=0.9,en;q=0.8");
        httpRequestMessage.Headers.Add("Cookie", "__utmc=266643403; __utmz=266643403.1537352460.3.3.utmccn=(referral)|utmcsr=google.co.uk|utmcct=/|utmcmd=referral; __utma=266643403.817561753.1532012719.1537357162.1537361568.5; __utmb=266643403; __atuvc=0%7C34%2C0%7C35%2C0%7C36%2C0%7C37%2C48%7C38; __atuvs=5ba2469fbb02458f002");


        var httpResponseMessage = httpClient.SendAsync(httpRequestMessage).Result;

        var httpContent = httpResponseMessage.Content;
        string result = httpResponseMessage.Content.ReadAsStringAsync().Result;

このプラグインはまだ完全ではないので、2行コメントアウトする必要がありましたが、それでも仕事は終わりました。

免責事項:私はとにかくTelerikまたはプラグインの作者のどちらにも関連付けられても承認されてもいません。

1
Amir No-Family

私にとって簡単な解決策は、CookieをHttpRequestMessageオブジェクトに設定することです。

protected async Task<HttpResponseMessage> SendRequest(HttpRequestMessage requestMessage, CancellationToken cancellationToken = default(CancellationToken))
{
    requestMessage.Headers.Add("Cookie", $"<Cookie Name 1>=<Cookie Value 1>;<Cookie Name 2>=<Cookie Value 2>");

    return await _httpClient.SendAsync(requestMessage, cancellationToken).ConfigureAwait(false);
}
0
Waqar UlHaq