有兩個域名
s.a.com 和 q.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的值(和添加一樣,省略掉前綴,域名前必須加.)
}
}