同域名下两个子级域名共享cookie

有两个域名

s.a.comq.a.com;

他们都是属于一个一级域名下的域名,并不是跨域;

前者为后台管理系统,有登录页面;后者为官网,没有登录功能;

现在的需求是:后台登录之后,官网也需要显示登录状态,后台退出之后,官网也会显示退出登录状态;

所以我们只需要在前者域名中写添加和删除cookie的代码即可。

添加cookie

//成功回调函数
success: function (data) {
    $.each(data, function (ele, index) {
      //ele是key;index是value
      addCookie(ele, index);
      setCookie(ele, index,1);//这里必须传入第三个参数
    });
}
 
function addCookie(objName, objValue, objHours) { //当前域名添加cookie
   var str = objName + "=" + escape(objValue);
   if (objHours > 0) { //为0时不设定过期时间,浏览器关闭时cookie自动消失
     var date = new Date();
     var ms = objHours * 3600 * 1000;
     date.setTime(date.getTime() + ms);
     str += "; expires=" + date.toGMTString();
   }
   document.cookie = str;
}
 
function setCookie(c_name,value,expiredays){  //为同级域名设置cookie
    var exdate=new Date();  
    exdate.setDate(exdate.getDate()+expiredays);  
    document.cookie=c_name+"="+escape(value)+((expiredays==null)?"":";expires="+exdate.toGMTString()+";path=/;domain=.a.com") //domain的值(省略掉前缀,域名前必须加.)
}

清除cookie

// 清除所有cookie
var keys = document.cookie.match(/[^ =;]+(?=\=)/g);
if(keys) {
      for(var i = keys.length; i--;){
          document.cookie = keys[i] + '=0;expires=' + new Date(0).toUTCString();
          document.cookie = keys[i] + '=0;path=/;domain=.b.com;expires=' + new Date(0).toUTCString();//清除一级域名下的或指定的,例如 .kevis.com   domain的值(和添加一样,省略掉前缀,域名前必须加.)<br>    }<br>}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SSO (Single Sign-On) 单点登录是指在访问多个系统或应用程序时,用户只需登录一次就可以访问所有的系统,而无需再次输入用户名和密码。基于cookie二级域名下跨域共享是指在跨域访问的情况下,通过设置cookie域名和路径,使得不同域名下的系统能够共享登录状态。 具体来说,当用户成功登录一个系统后,该系统会生成一个包含用户登录状态的cookie,并设置该cookie域名为当前系统的二级域名。然后,该cookie会被发送给浏览器保存,在用户访问其他系统时,浏览器会自动通过cookie将用户的登录状态传递给其他系统。 为了实现跨域共享,所有需要实现SSO的系统的二级域名需要设置为相同的根域名。例如,系统A的域名为a.example.com,系统B的域名为b.example.com,则它们的根域名为example.com。为了在这两个系统之间实现跨域共享,可以将cookie域名设置为.example.com,这样两个系统就可以共享同一个cookie。 当用户访问系统A时,系统A会检查是否存在含有登录状态的cookie,如果存在则表示用户已经登录,可以直接访问系统A的资源。如果用户访问系统B,系统B也会检查是否存在含有登录状态的cookie,如果存在则表示用户已经登录,可以直接访问系统B的资源。 通过基于cookie二级域名下跨域共享的方式,SSO单点登录实现了用户在不同系统间的无缝登录体验,提高了用户的使用便捷性和系统的安全性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值