cookie那些事

cookie那些事

本文面向对cookie有基本了解的读者,小白出门左转

设置cookie (HTTP 响应头)

Set-Cookie: {name}={value};path={path};domain={domain};expires={expires},secure;HttpOnly;  //多个cookie就发送多个Set-Cookie头

发送cookie (HTTP 请求头)

Cookie: {name}={value};{name2}={value2}    //多个cookie以";"号隔开

请求头格式比较简单,这里主要说下响应头

name        cookie名称
value       cookie值,部分语言会有子cookie实现,格式为 {key1}={value1}&{key2}={value2}
path        cookie有效路径,不同语言默认策略不一样,部分语言默认"/",部分语言默认当前页面所在目录
domain      cookie有效域名,默认当前域名,二级域名可以访问主域名下的cookie(需要以"."开头,如".aaa.com"),三级域名可以访问二级域名下的cookie,以此类推。  如果当前访问的是www.aaa.com,而设置Domain为www.bbb.com,则属于第三方cookie(下边详述)
expires     cookie有效期,不设置默认当前session,浏览器关闭则cookie失效,如果expires时间早于浏览器时间,则cookie立即失效
secure      带上这个标识表示只有在https协议的请求中才发送此cookie
HttpOnly    表示cookie只允许通过服务器修改,客户端js不允许修改`

cookie跨域

主域名相同

如www.aaa.com和bla.aaa.com
设置cookie的domain为".aaa.com"

主域名不同

如www.aaa.com和www.bbb.com
设置第三方cookie

第三方Cookie

  • 什么是第三方cookie?

    访问www.aaa.com的时候设置了一个domain=www.bbb.com的cookie,对于www.aaa.com来说,这个cookie就是第三方的

  • 哪些场景需要第三方cookie?

    比如,两个不同域名的网站做sso,如www.tmall.comwww.taobao.comwww.sina.comwww.weibo.com
    比如,广告服务商追踪用户行为,根据用户浏览记录给用户推荐更符合胃口的广告(这里存在隐私泄漏风险,因为广告服务商可以获取用户的浏览记录)

  • 怎么做?

    以广告追踪为例子,www.ccc.com是个广告服务供应商,www.aaa.comwww.bbb.com想接入它的广告

  1. www.aaa.comwww.bbb.com在所有页面上加一行代码:<script type="text/javascript" src="http://www.ccc.com:1234/ads.aspx"></script>

  2. www.ccc.com在这个页面上种下一个domain=www.ccc.com的cookie,这样www.aaa.comwww.bbb.com的所有页面在打开的时候都会给www.ccc.com发送一个带cookie的请求,www.ccc.com拿到这个cookie后就可以区分用户了,然后通过referer拿到用户正在浏览的页面地址,就可以掌握用户的浏览行为了

    由上可见,如果一个广告服务商接入的客户足够多,就可以掌握一个用户大多数的浏览行为,因为这个用户浏览的大多数网站可能都是这个服务商的客户,而且他们共用一个cookie

  • 浏览器设置
浏览器 默认设置是否支持第三方cookie DNT设置 如何阻止第三方cookie
Chrome 设置-随浏览器一起发送"不跟踪"请求 设置-内容设置-阻止第三方cookie和网站数据
Firefox 选项-隐私-要求此网站不要跟踪您 选项-隐私-使用自定义历史记录设置-接受第三方cookie-总不
IE 需要额外的P3P响应头 选项-高级-向你在IE中访问的站点发送"Do Not Track"请求 选项-隐私-高级-替代自动cookie处理-第三方cookie-阻止
  1. IE的默认安全性等级为中,将阻止没有精简隐私策略的第三方cookie,具体P3P协议详情,请参考http://www.w3.org/P3P/
    这里给个P3P的例子P3P:CP="CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR"
  2. DNT设置后,请求头中会加上 DNT:1,如果网站遵守DNT协议,就不再种第三方cookie了,但也可以耍赖不遵守,全看素质
  3. 如果用户设置阻止第三方cookie了,那对不起,所有第三方cookie就无效了

Cookie安全

由于cookie记录了用户的身份,因此成为攻击者的热门攻击对象,开发者稍有疏忽,就可能节操不保
这里列举下可能的攻击方式,详情请自行百度之,总之不要相信cookie,不要放未加密的敏感信息到cookie中,cookie在使用前要校验,合理使用secure和HttpOnly,由于第三方cookie的存在,敏感的操作需要验证,不要相信正在操作的人就是当前登录的用户,看下CSRF攻击吧

XSS,反射型XSS,session劫持,CSRF攻击

第三方cookie代码实例(asp.net)

www.ccc.com是广告服务提供商,www.aaa.comwww.bbb.com接入了它的广告

  1. 修改host
    127.0.0.1 www.aaa.com www.bbb.com www.ccc.com
  2. www.ccc.com广告服务商ads.aspx代码
private static IDictionary<string,IList<string>> histories = new Dictionary<string, IList<string>>();
protected void Page_Load(object sender, EventArgs e)
{
    Response.ContentType = "text/javascript";
    //用户开启了浏览器"不跟踪"选项
    if (!string.IsNullOrWhiteSpace(Request.Headers.Get("DNT")) && int.Parse(Request.Headers.Get("DNT")) == 1)
    {
        Response.Write(@"document.write('用户开启了浏览器Do Not Track选项,我比较讲究,遵守这个约定,不跟踪你了,只能给你展示大众版的广告了');");
        return;
    }

    var uuid = Request.Cookies["uuid"];
    //种第三方cookie
    if (uuid == null) {
        uuid = new HttpCookie("uuid")
        {
            Value = Guid.NewGuid().ToString(),
            Domain = "www.ccc.com",
            Expires = DateTime.Now.AddYears(70),
        };
        Response.Cookies.Add(uuid);
        //使用P3P协议提高cookie种上的概率
        Response.Headers.Add("P3P", "CP=\"CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR\"");
    }
    //获取用户正在浏览的网址
    var referer = Request.Headers.Get("Referer");

    //记录用户访问历史
    if (!histories.ContainsKey(uuid.Value)) {
        histories[uuid.Value] = new List<string>();
    }
    histories[uuid.Value].Add(DateTime.Now + ": " + referer);

    Response.Write(@"document.write('<br><br>blabla这里是根据你浏览的网址给你推荐最合适的广告'+
            ',不要问我怎么知道哪个网址有什么内容,也不要问我怎么知道哪些广告最适合你,我会告诉你我有高大上的算法嘛<br><br>');");
    Response.Write(@"document.write('下边是你的浏览记录(不好意思,我看到了羞羞的东东):<br>');");

    foreach (string history in histories[uuid.Value]) {
        Response.Write("document.write('" + history + "<br>');");
    }
}
  1. www.aaa.comwww.bbb.com页面代码

     <script type="text/javascript" src="http://www.ccc.com:1234/ads.aspx"></script>
    
  2. 打开www.aaa.comwww.bbb.com页面就可以互相看到访问记录了

异类 falsh cookie

这货太变态,不在本文讨论范围内,有兴趣的可以自行百度之
总而言之就一句话,cookie能干的它能干,cookie不能干的它也能干,当然cookie没有的问题它也有了

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,133评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,682评论 3 390
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,784评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,508评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,603评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,607评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,604评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,359评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,805评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,121评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,280评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,959评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,588评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,206评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,193评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,144评论 2 352

推荐阅读更多精彩内容