java cef cookie_CEF 设置Cookie

简单地说,cookie 就是浏览器储存在用户电脑上的一小段文本文件。cookie 是纯文本格式,不包含任何可执行的代码。一个 Web 页面或服务器告知浏览器按照一定规范来储存这些信息,并在随后的请求中将这些信息发送至服务器,Web 服务器就可以使用这些信息来识别不同的用户。大多数需要登录

的网站在用户验证成功之后都会设置一个 cookie,只要这个 cookie 存在并可以,用户就可以自由浏览这个网站的任意页面。再次说明,cookie 只包含数据,就其本身而言并不有害。

设置Cookie的失效时间:

如果Cookie没有设置expires属性,那么 cookie 的生命周期只是在当前的会话中,

关闭浏览器意味着这次会话的结束,此时 cookie 随之失效。

CEF3中,CefCookieManager这个类就是用来管理cookies的。

在头文件cef_cookies中,在cef_cookies_capi.h里,有详细的注释,和上边链接里的文档说明一样。

Cookies的管理无外乎Cookies的设置、获取、删除、查找,外加一个存储位置的设置。

Method Summary

static CefRefPtr< CefCookieManager >

CefString& path, bool persist_session_cookies, CefRefPtr callback )

Creates a new cookie manager.

virtual bool

virtual bool

static CefRefPtr< CefCookieManager >

virtual bool

virtual bool

CefString& path, bool persist_session_cookies, CefRefPtr callback )= 0

Sets the directory path that will be used for storing cookie data.

virtual void

virtual bool

virtual bool

CefString& url, bool includeHttpOnly, CefRefPtr visitor )= 0

Visit a subset of cookies on the IO thread.

std::wstring username_key = L"username";

std::wstring username_value= L"chechen";

std::wstring domain= L"www.cnblogs.com/chechen"CefRefPtr manager =CefCookieManager::GetGlobalManager();

CefCookie cookie;

CefString(&cookie.name).FromWString(username_key.c_str());

CefString(&cookie.value).FromWString(username_value.c_str());

CefString(&cookie.domain).FromWString(domain.c_str());

CefString(&cookie.path).FromASCII("/");

cookie.has_expires= true;//设置Cookie时间

cookie.expires.year = 2200;

cookie.expires.month= 4;

cookie.expires.day_of_week= 5;

cookie.expires.day_of_month= 11;

domain= L"https://" +domain;

CefPostTask(TID_IO, NewCefRunnableMethod(manager.get(), &CefCookieManager::SetCookie,CefString(domain.c_str()), cookie));

注意:cookie.domain是不带”https://”的,而CefString(domain.c_str())中的domain是带”https://“的,一定要注意。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值