Chromium 的 Cookie 机制
转载来自:https://blog.wandoer.com/coding/chromium-%e7%9a%84-cookie-%e6%9c%ba%e5%88%b6.htm#more-1341
Cookie
指某些网站为了辨别用户身份而储存在用户本地终端(Client Side)上的数据,它是一种古老的技术, 由网景公司的前雇员卢·蒙特利在1993年3月发明。
Cookie 格式是一系列键值对, 以 ;
组合,如下
1
|
TBLkisOn=0; GeoIP=US:CA:Los_Angeles:34.05:-118.26:v4; mwPhp7Seed=9d0
|
当然, Cookie还有更多的内容,如创建时间,过期时间等,对应的域等等。一般而言,为了安全只允许页面访问该域下的Cookie.
根据 Cookie 的时效性可以将 Cookie 分为两类,一种是会话型Cookie (Session Cookie), 只保存于内存中, 当浏览器退出的时候,即清除这些 Cookie. 第二种是持续型 Cookie (Persistent Cookie),也就是当浏览器退出的时候仍然保留的Cookie.
Chromium 中Cookie操作的类结构如下所示:
其中 CookieStore
是主要的导出接口,CookieMonster
是重要的实现接口,它相当于是 Cookie 的管理器。它有几个作用:一是实现 CookieMonster
中的接口,二是报告前者的事件,如 Cookie 更新信息等,三是 Cookie对象(即 CanonicalCookie
) 的集合。PersistentCookieStore
持久化类,SQLitePersistentCookieStore
是持久化的具体实现,负责实际的存储动作。
Chrome 的 Cookie使用 Sqlite存储,是位于 %AppData%\Local\Google\Chrome\User Data\Default
目录下的 Cookies
文件。
创建一个 CookieStore 对象的方式是调用 content::CreateCookieStore(const CookieStoreConfig& config)
接口,CookieStoreConfig
定义如下:
1
2
3
4
|
CookieStoreConfig(const base::FilePath& path,
SessionCookieMode session_cookie_mode,
storage::SpecialStoragePolicy* storage_policy,
net::CookieMonsterDelegate* cookie_delegate);
|
其中 path
是 cookie 文件(一个 sqlite 数据库文件) 的路径,如果该路径不存在,则会创建一个会话型的 CookieStoresession_cookie_mode
的定义及解释如下:
1
2
3
4
5
|
enum SessionCookieMode {
EPHEMERAL_SESSION_COOKIES, //不作持久化
PERSISTANT_SESSION_COOKIES, //如果下次以 RESTORED_SESSION_COOKIES 的方式打开cookie,则可以恢复持久化
RESTORED_SESSION_COOKIES //持久化存储
};
|
GetCookiesWithOptionsAsync 的定义如下:
1
2
3
|
void GetCookiesWithOptionsAsync(const GURL& url,
const CookieOptions& options,
GetCookiesCallback callback)
|
其中 callback 应为 void(const std::string& cookie)
的 functional, 可以使用 base::Bind
来绑定回调函数。务必要注意 CookieStore
的生命周期要大于回调的生命周期,否则回调将不会被 invoke.