本文主要经过整理RFC6265 - HTTP State Management Mechanism文档的域名和路径匹配章节,而后加以实验验证,最后梳理出一些技术要点,仅供你们参考。html
假设request_domain为请求域名,cookie_domain为cookie的domain属性,若是request_domain和cookie_domain以点"."结尾,则先将尾部的点"."移除。 若是request_domain和cookie_domain知足如下任一个条件,则称request_domain和cookie_domain匹配:
** 1. request_domain和cookie_domain是同级域名,而且相等 **api
** 2. request_domain和cookie_domain不一样级,而且cookie_domain是request_domain的后缀 **浏览器
cookie_domain(google.com)和cookie_domain(.google.com)匹配全部子域名cookie
不匹配示例:dom
假设request_path为请求路径,cookie_path为cookie的path属性。 若是cookie_path和request_path知足如下任一个条件,则称cookie_path和request_path匹配:
** 1. cookie_path和request_path是同级路径,而且相等 **google
** 2. cookie_path和request_path不是同级路径,而且cookie_path是request_path的前缀 **htm
cookie_path(/)匹配全部request_path文档
不匹配示例:get
假设当前请求的域名是request_domain, 响应中Set-Cookie的域名是cookie_domain,路径是cookie_path,则:域名
能够的,只要同时知足Domain Match和Path Match便可。