C# httpclient获取cookies实现模拟web登录

发布时间 2023-07-09 10:42:47作者: 易胆大888

目前在公司做一款平台化的产品,我主要负责PC端上的开发,在产品推荐过程中为了节省开发时间很多功能模块没来得及做原生,用CEF嵌入了很多带功能web页面,与客户端进行交互从而实现功能。

在二期开发中,产品需求说明书中需要把登录功能放在客户端来做,这当中涉及到一个问题客户端做登入登出很简单,但是很难通知到web平台登入登出。

我的想法是通过动态get/set浏览器cookies+refresh浏览器来实现平台登录。

web端登录本身是相同URL在不同环境下(cookies/session两种)有不通的相应规则。

下面我来阐述做法

通过System.Net.Http中httpclient类调用接口实现客户端登录。

  1.  
    // 创建请求
  2.  
    HttpClient httpClient = new HttpClient();
  3.  
    httpClient.Timeout = TimeSpan.FromSeconds(10);
  4.  
    string url = ConfigHelper.WebServerUrl + "p/user/Autologin";
  5.  
    var response = await httpClient.PostAsync(url, this.GetPostParameter());
  6.  
    // 请求失败
  7.  
    if (!response.IsSuccessStatusCode)
  8.  
    {
  9.  
    return null;
  10.  
    }
  11.  
    //这句话是关键点
  12.  
    var cookies = response.Headers.GetValues("Set-Cookie");
  13.  
    // 解析请求结果
  14.  
    string content = await response.Content.ReadAsStringAsync();

在response中会带有cookies信息包括JSESSIONID和GSID。.Net中HttpCilent比较老旧没有解析header的方法,不如Java全面。需要人工解析。

在返回值成功后,客户端即应该已经算作登录状态了。但web页面并不知道我们登没登陆。

之后与web页面的接口交互,如果是登录后的接口需要携带session信息。有如下两种方法:

  1.  
    // 创建请求
  2.  
    //将刚才的cookies放入cookiescontainer并加入初始化
  3.  
    var handler = new HttpClientHandler() { CookieContainer = cookiescontainer, AllowAutoRedirect = true, UseCookies = true };
  4.  
     
  5.  
    HttpClient httpClient = new HttpClient(handler);
  6.  
    httpClient.Timeout = TimeSpan.FromSeconds(10);
  7.  
     
  8.  
    string url = ConfigHelper.WebServerUrl + "p/user/activeUser";
  9.  
    var response = await httpClient.PostAsync(url, this.GetUpdatePostParameter());

或者 通过手写cookies的方式也行
  1.  
    string JSESSIONID =“123456”;
  2.  
    string GSID=“456789”;
  3.  
    var handler = new HttpClientHandler() { UseCookies = false }; //手写cookies
  4.  
    HttpClient httpClient = new HttpClient(handler);
  5.  
    httpClient.Timeout = TimeSpan.FromSeconds(10);
  6.  
    string url = ConfigHelper.WebServerUrl + "p/user/activeUser";
  7.  
     
  8.  
    var message = new HttpRequestMessage(HttpMethod.Post, url);
  9.  
    message.Content = this.GetUpdatePostParameter();
  10.  
    var cookie = "JSESSIONID" + "=" + JSESSIONID + ";" + "GSID" + "=" + GSID;
  11.  
    message.Headers.Add("Cookie", cookie);
  12.  
     
  13.  
    var response = await httpClient.SendAsync(message);

这样可以模拟web页面登陆后与其内部接口相交互。

还有一半功能需要注意,在CEF中进行页面跳转时,由于登录不是通过web页面本身进行的,而是客户端主动请求的,这样浏览器并不知道用户是否成功登录,我们还需要对浏览器cookies进行配置。

  1.  
    var manager = CefCookieManager.GetGlobal(null);
  2.  
    //在这个manager中,有对cefcookies进行添加删除刷新等操作

这样就基本实现了在客户端模拟web登录