C# HttpClient設置cookies的兩種辦法


前言:最近公司使用HttpClient對象在發送請求,拋棄了之前的HttpWebRequest,使用httpClient有個好處:就是可以只使用一個HttpClient的實例,去完成發送所有的請求數據(地址,請求數據,類型,Cookie等)。   

而傳統的HttpWebRequest每次請求需要創建一個單獨的實例,且規避了一個老問題:Socket  連接釋放不及時的問題。   

下面的是轉發其他道友的文章,主要是在使用的過程中,自身需要發送一個自定義的Cookie到目標服務器,但是死活發送不過去,最后百度其他道友的文章發現如果需要發送自己的Cookie,需要做一個設置:

var handler = new HttpClientHandler() { UseCookies = false};
var client = new HttpClient(handler);// { BaseAddress = baseAddress };


道友文章地址:https://www.cnblogs.com/xiaozhu39505/p/8033108.html     原文如下:

 

一般有兩種辦法

第一種handler.UseCookies=true(默認為true),默認的會自己帶上cookies,例如

var handler = new HttpClientHandler() { UseCookies = true };
var client = new HttpClient(handler);// { BaseAddress = baseAddress };
client.DefaultRequestHeaders.Add("user-agent", "Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:57.0) Gecko/20100101 Firefox/57.0");
client.DefaultRequestHeaders.Add("Connection", "Keep-Alive");
client.DefaultRequestHeaders.Add("Keep-Alive", "timeout=600");
var content = new FormUrlEncodedContent(new[]
            {
                new KeyValuePair<string, string>("email", "xxxx"),
                new KeyValuePair<string, string>("password", "xxxx"),
            });
var result = await client.PostAsync("https://www.xxxx.com/cp/login", content);
result.EnsureSuccessStatusCode();

這種情況post請求登陸成功后,重定向到別的頁面,也會自動帶上cookies。如果把handler.UseCookies設置為false,登陸后重定向的話不會自動帶上cookies,則又會跳轉到登陸頁面。

 

第二種設置 handler.UseCookies = false時,則需要手動給headers上加入cookies.

var handler = new HttpClientHandler() { UseCookies = false};
var client = new HttpClient(handler);// { BaseAddress = baseAddress };
var message = new HttpRequestMessage(HttpMethod.Get, url);
message.Headers.Add("Cookie", "session_id=7258abbd1544b6c530a9f406d3e600239bd788fb");
var result = await client.SendAsync(message);
result.EnsureSuccessStatusCode();

如果使用場景是:抓取需要登陸后才能看到的網頁數據,建議使用第一種,不需要設置任何cookies,httpclient會自動把登陸后的cookies放置到后面的請求中。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM