Winform使用CefSharp和HttpWebRequest如何保持会话Session
之前我们使用CefSharp,在Winform中,使用ChromiumWebBrowser加载了web项目的页面。
并且通过html页面的js调用了本地的窗口。
那么下一个问题来了。
为了保障系统安全性,项目都会使用session会话来进行权限认证。
那么,我在新打开的winform窗体中,肯定是要获取数据并且进行交互操作的。也就是说要用到HttpWebRequest。
然后HttpWebRequest肯定会产生新的session,然后通不过后台验证。这时候怎么办呢。
有经验的都知道,服务器(iis或者tomcat,apache2,nigx)都是通过请求中的sessionid来判断是否是相同会话的。当然,不同服务器的sessionid的名称有区别,这个无关紧要。重要的是,sessionid都是存在cookie中进行保存的。毕竟服务器处理每条请求的时候,都是新建页面对象进行处理。所以请求都是短连接,只能通过这种机制来进行。
那么问题改变方向了,如何把cookie从ChromiumWebBrowser中读取出来,然后再HttpWebRequest中发送过去呢?
CefSharp肯定是提供了方法的。
首先实现一个Cookie读取操作的接口,CefSharp.ICookieVisitor,实例化Visit方法。这个方法会返回Cookie对象,当然是CefSharp的Cookie对象,不是System.net的,要注意类型。这里面开放了一个SendCookie的代理,用来开放Cookie。
public class CookieVisitor : CefSharp.ICookieVisitor
{
public event Action<CefSharp.Cookie> SendCookie;
public void Dispose()
{
//throw new NotImplementedException();
}
public bool Visit(CefSharp.Cookie cookie, int count, int total, ref bool deleteCookie)
{
deleteCookie = false;
if (SendCookie != null)
{
SendCookie(cookie);
}
return true;
}
}
然后再Form窗体中实现如下事件。这个时间会在页面加载完毕时触发,在页面中绑定SendCookie事件实现。
private void browser_FrameLoadEnd(object sender, CefSharp.FrameLoadEndEventArgs e)
{
var cookieManager = CefSharp.Cef.GetGlobalCookieManager();
CookieVisitor visitor = new CookieVisitor();
visitor.SendCookie += visitor_SendCookie;
cookieManager.VisitAllCookies(visitor);
}
public static string cookies;
private void visitor_SendCookie(CefSharp.Cookie obj)
{
cookies += obj.Domain.TrimStart('.') + "^" + obj.Name + "^" + obj.Value + "$";
}
这上面是直接定义了存储Cookie的字符串,然后把CefSharp给的Cookie存下来了。只存了几个关键属性,用字符分割了一下。 重点只是演示。其实是可以直接转换成System.Net.Cookie对象存储的。后面会用到。建议调试过程中Debug看一下。
public static CookieCollection GetCookieCollection()
{
CookieCollection cookieCollection = new CookieCollection();
string[] arr = cookies.Split('$');
foreach(string s in arr)
{
if (string.IsNullOrEmpty(s))
continue;
string[] car = s.Split('^');
System.Net.Cookie cookie = new System.Net.Cookie();
cookie.Domain = car[0];
cookie.Name = car[1];
cookie.Value = car[2];
cookieCollection.Add(cookie);
}
return cookieCollection;
}
然后就是上面这段了。在使用HttpWebRequest的时候,会用到CookieCollection来设置Cookie,这里做下解析转换。
生下的就简单了,在HttpWebRequest初始化的时候,
request.CookieContainer = new CookieContainer();
request.CookieContainer.Add(GetCookieCollection());
这样搞一下就好了。
然后就能实现,使用与Browser中同一Session了,不用单独在处理login了,也不用传什么登录用户什么的了。一劳永逸。
接下来说一下,怎么处理html中 “_blank”的问题吧。我这里用的是tabCtrl,所以希望打开新页面,而不是给我打开心浏览器窗体。
————————————————
版权声明:本文为CSDN博主「b哈利路亚d」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/lanwilliam/article/details/79640597
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现