Cookie会话跟踪技术

cookie是存放在浏览器上的一个只有4kb的容器,他可以解决http请求的无状态问题,而且每次会话里面都会保存对应的sessionId 且每次请求都会带上里面存放的String类型的值。

cookie里面的数据存储以键值对的形式存储 key=value

完整格式
name=value;[expires=date];[path=路径];[domain=域名];[secure]

其中中括号[]表示该值是可选。

name=value: 为你要保存的键值对(必选)

expires=date: 表示cookie的失效时间, 默认是浏览器关闭时失效(可选)

path=路径: 访问路径, 默认为当前文件所在目录(可选)

domain=域名: 访问域名, 限制在该域名下访问(可选)

secure: 安全设置, 如果设置了则必须使用https协议才可获取cookie(可选)

1,获取和设置cookie

        使用document对象来获取和设置cookie

//设置cookie和获取cookie
document.cookie = "user="+"张三"; //设置
console.log(document.cookie);  //获取

//URI编码后设置cookie, 和URI解码后获取cookie
document.cookie = "user2=" + encodeURIComponent("张三");
console.log(decodeURIComponent(document.cookie));

2,expires=失效时间

        失效时间: 表示cookie会在该时间被删除掉, 默认是浏览器关闭的时候;

可以自己设置cookie的失效时间。 如设置7天后再删除cookie
var date = newDate();  
date.setDate(date.getDate() +7); 
document.cookie = “user=张三;expires=” + date;

主动删除cookie 失效时间设置在现在时间或现在之前的时间即可删除指定cookie name值为指定要删除的那个cookie

var date = new Date();
document.cookie = “user=张三;expires=” + date;

3  path=路径

设置路径后, 则只有设置的那个路径文件才可以访问cookie, 默认为当前文件所在目录 一般设置path=/, 表示磁盘(域名)根目录, 则其他路径也可以获取到该cookie值

document.cookie = “user=abc;expires=" + date + ";path=/"; 

注意: 在设置路径path时, 要记得设置失效时间expires

4,domain=域名

用于限制只有设置的域名才可以访问,没有设置则默认为当前域名。
document.cookie = “user=张三;domain=www.baidu.com”;

5,secure 安全设置

指明必须通过安全的通信通道来传输(HTTPS)才能获取 cookie。 
document.cookie = “user=张三;secure”;

Cookie的封装

将cookie相关的操作封装在函数中, 方便以后调用, 一般我们只要设置name, value, expires, path即可;

//设置cookie


function setCookie(name, value, expires, path) {
     var cookieText = encodeURIComponent(name) + "=" + encodeURIComponent(value);
     if (expires instanceof Date) {
          cookieText += ";expires="+expires;
     }
     if (path) {
          cookieText += ";path="+path;
     }
     document.cookie = cookieText;
     return decodeURIComponent(document.cookie);
}

获取cookie

function getCookie(name) {	
      var cookie = decodeURIComponent(document.cookie);	
      var arr = cookie.split(“; ”);	
      for (var i=0; i<arr.length; i++) {			
            var arr2 = arr[i].split(“=”);		
            if (arr2.length >= 2) {		
	   if (arr2[0] == name) {				
                       return arr2[1];			
                  }		
            }	
      }	
      return “”;
}

删除cookie

function removeCookie(name) {
     document.cookie=encodeURIComponent(name)+“=; expires=” + new Date();
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值