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.com和www.taobao.com,www.sina.com和www.weibo.com

比如,广告服务商追踪用户行为,根据用户浏览记录给用户推荐更符合胃口的广告(这里存在隐私泄漏风险,因为广告服务商可以获取用户的浏览记录)

  • 怎么做?

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

  1. www.aaa.com和www.bbb.com在所有页面上加一行代码:<script type="text/javascript" src="http://www.ccc.com:1234/ads.aspx"></script>
  2. www.ccc.com在ads.aspx页面上种下一个domain=www.ccc.com的cookie,这样www.aaa.com和www.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的存在,敏感的操作需要验证,不要相信正在操作的人就是当前登录的用户

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

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

 

www.ccc.com是广告服务提供商,www.aaa.com和www.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>‘);");
        }
    }
  3. www.aaa.com和www.bbb.com页面代码
    <script type="text/javascript" src="http://www.ccc.com:1234/ads.aspx"></script>
  4. 打开www.aaa.com和www.bbb.com页面

 

异类 falsh cookie

 

这货太变态,不在本文讨论范围内,有兴趣的可以自行百度之

总而言之就一句话,cookie能干的它能干,cookie不能干的它也能干,当然cookie没有的问题它也有了

时间: 2024-11-10 07:59:03

cookie那些事的相关文章

web前端细解cookie那些事

web前端细解cookie那些事,在互联网时代,IT行业飞速发展,带动了web前端开发行业的兴趣.由于行业新兴起时间不久,专业人才缺乏,薪资待遇较高,已成为众多IT学子选择就业的首选,今天就为分享一些有用的干货.   1.什么是cookie cookie是浏览器缓存 缓存是什么?数据交换的缓冲区>>>>临时储存. cookie的特性, cookie生效在同一个域名下.cookie储存量有限.4~10k,不能储存50条,有过期时间. >>>>缓存 2.cook

Python请求自动处理cookie

在平时测试当中经常会遇到使用python脚本来模拟http请求的操作,在做一次接口[http请求,返回json]测试时,开发提供的http接口在请求时,会被filter拦截,验证请求者的session是否合法,由于我们是直接请求,没有附带任何的cookie与headers,那如何让我们合法的进行接口的请求,并继续测试呢?详见下面描述: 在使用系统之前,我们都会经过一个登录的操作,这个登录操作就会把我们的sessionId的状态属性设置为合法[不同的系统,细节不同,大体都类似],我们要是想直接请求

网站常见的鉴权认证方式有哪几种?

一.什么是鉴权 鉴权(authentication)是指验证用户是否拥有访问系统的权利.传统的鉴权是通过密码来验证的.这种方式的前提是,每个获得密码的用户都已经被授权.在建立用户时,就为此用户分配一个密码,用户的密码可以由管理员指定,也可以由用户自行申请.这种方式的弱点十分明显:一旦密码被偷或用户遗失密码,情况就会十分麻烦,需要管理员对用户密码进行重新修改,而修改密码之前还要人工验证用户的合法身份. 为了克服这种鉴权方式的缺点,需要一个更加可靠的鉴权方式.目前的主流鉴权方式是利用认证授权来验证数

关于Cookie安全性设置的那些事

一.标题:关于Cookie安全性设置的那些事 副标:httponly属性和secure属性解析 二.引言 经常有看到XSS跨站脚本攻击窃取cookie案例,修复方案是有httponly.今天写出来倒腾下... 2.1首先必须的预备cookie知识.假如你第一次认识cookie,请先阅读这篇文章: js于cookies.zip.google cookie. 三.Cookie属性 cookie内容,如图所示:   HTTP response header: Set-Cookie: <name>=&

Session与Cookie间不得不说的一些事

在很久很久以前,刚有浏览器和网页的时候,web开发者发现了一个问题,我必须要在客户端这边保存一些东西才能实现某些功能,比如大家喜闻乐见的购物车.用户登录.自动登陆等.但是客户端只有一个浏览器,怎么在用户也就是客户端那边保存数据呢?于是大佬们一拍桌子,Cookie就诞生了! 我把Cookie理解为一个键-值形式存储再加上有效时间的一个容器,除此之外Cookie还有一个作用范围的概念(作用范围指的是域和路径,域的意思是根域名和端口,除非在设置cookie的时候特别指定域名),可以认为在同一个域里面的

cookie这件事。

没深入理解的东西,都是没有被坑过的.. 我这次理解cookie了. 1.cookie是什么. 是浏览器提供的,写在硬盘里的,交给document作为属性的,可以提供给js使用,是在一个域下可以共享的全局的: 它可以记下任何你想记的东西,比方说你想记人家的登陆状态.浏览行为.等等. 但是它是可以被用户禁用的.可以被删除.纯文本方式保存的. 说白了就是,我想记忆你的行为,好,记下了,下次我来取,可以跟踪你.但是我记忆的别人可不能用~只能我用~我的别的域也不能用,只能我自个当前域可用~你不想我记,可以

扒一扒Cookie和Session的那些事

首先,众所周知:cookie是客户端技术——cookie是把用户的数据写给用户的浏览器:session是服务端技术——session是把用户的数据写到用户独占的session中. 下面具体来扒一扒他们之间数据保存的区别: cookie保存用户数据的原理: Cookie是客户端技术,程序把每个用户的数据以cookie的形式写给用户各自的浏览器. 当用户使用浏览器再去访问服务器中的web资源时,就会带着各自的数据去.这样,web资源处理的就是用户各自的数据了. session保存用户数据的原理: S

session和cookie的一些事

这些都是基础知识,不过有必要做深入了解.先简单介绍一下. 二者的定义: 当你在浏览网站的时候,WEB 服务器会先送一小小资料放在你的计算机上,Cookie 会帮你在网站上所打的文字或是一些选择, 都纪录下来.当下次你再光临同一个网站,WEB 服务器会先看看有没有它上次留下的 Cookie 资料,有的话,就会依据 Cookie 里的内容来判断使用者,送出特定的网页内容给你. Cookie 的使用很普遍,许多有提供个人化服务的网站,都是利用 Cookie 来辨认使用者,以方便送出使用者量身定做的内容

cookie 和 session 的一些事 中间件

cookie 和 session cookie 1. 保存在浏览器上一组组键值对,服务器让浏览器进行设置. 2. 为什么要用cookie? HTTP协议是无状态.使用cookie保存状态. 3. django中的操作 设置: response.set_cookie(key,value,max_age=5) response.set_signed_cookie(key,value,max_age=5,salt='xxx') 获取: request.COOKIES request.COOKIES[k