首頁 > web前端 > js教程 > 主體

瀏覽器儲存技術cookie、session的實例介紹

零下一度
發布: 2017-06-28 09:28:24
原創
1506 人瀏覽過

HTTP無狀態協定是指協定對於事務處理沒有記憶能力。
會話追蹤
協定的狀態是指下一次傳輸可以「記住」這次傳輸訊息的能力,無狀態是指同一個會話(注意什麼叫同一個會話)
的連續兩個請求互相不了解,當瀏覽器發送請求給伺服器的時候,伺服器回應,但是同一個瀏覽器再發送請求給
伺服器的時候,他會回應,但是他不知道你就是剛才那個瀏覽器,每一次請求和回應都是相對獨立的。

Cookies最典型的應用程式是判定註冊使用者是否已登入網站,使用者可能會得到提示,是否在下次進入此網站時保留使用者資訊以便簡化
登入手續,這些都是Cookies的功用。另一個重要應用場合是「購物車」之類處理。使用者可能會在一段時間內在同一家網站的不同頁面
中選擇不同的商品,這些資訊都會寫入Cookies,以便在最後付款時提取資訊。

Javascript使用cookie
假設有這樣一種情況,在某個用例流程中,由A頁面跳至B頁面,若在A頁面中採用JS用變數temp保存了某一變數的值,在B頁面的時候,
同樣需要使用JS來引用temp的變數值,對於JS中的全域變數或靜態變數的生命週期是有限的,當發生頁面跳躍或頁面關閉的時候,
這些變數的值會重新載入,也就是沒有達到保存的效果。解決這個問題的最好的方案是採用cookie來保存該變數的值,那麼如何來設定和讀取
取cookie呢?
首先需要稍微了解一下cookie的結構,簡單地說:cookie是以鍵值對的形式保存的,也就是key=value的格式。各個cookie之間一般是以「;」分隔


在H5中webStorage其實就是在web上儲存數據,分為兩種:
 sessionStorage 在瀏覽器關閉時儲存的資料將消失---暫存
 localStorage 可以一直存在--- 永久儲存

設定
session storage:
sessionStorage.setItem("smessage",dataDom.value);

取得
sessionStorage.getItem("smessage")

removeItem刪除key
用途:刪除指定key本機儲存的值
用法:.removeItem(key)
程式碼範例:
sessionStorage.removeItem("key"); localStorage.removeItem("site");


clear清除所有的key/value
用途:清除所有的key/value
用法:.clear()
程式碼範例:
sessionStorage.clear(); localStorage.clear();

1、cookie一般不大於4095kb;設定過多存取很慢;
2、客戶端與伺服器都能存取資料
3、有有限期

local storage:只有本地瀏覽器能訪問,每個網域大小5M
沒有過期時間;即存即取;


cookie是以鍵值對的形式儲存的,即key=value的格式。各個cookie之間一般是以「;」分隔。
document.cookie="name="+username;
var username=document.cookie.split(";")[0].split("=")[1];


#//JS操作cookies方法!
//寫cookies
function setCookie(name,value)
{
var Days = 30;
var exp = new Date();
exp.setTime(exp.getTime() + Days*24*60*60*1000);
document.cookie = name + "="+ escape (value) + ";expires=" + exp. toGMTString();
}

//取得cookie
function getCookie(name)
{
var arr,reg=new RegExp("(^| )"+name+" =([^;]*)(;|$)");
if(arr=document.cookie.match(reg))
return unescape(arr[2]);
else
return null;
}
//刪除cookie
function delCookie(name)
{
var exp = new Date();
exp.setTime(exp.getTime() - 1);
var cval=getCookie(name);
if(cval!=null)
document.cookie= name + "="+cval+";expires="+exp.toGMTString() ;
}
//使用範例
setCookie("name","hayden");
alert(getCookie("name"));
//如果需要設定自訂過期時間
//那麼把上面的setCookie 函數換成下面兩個函數就ok;
//程式碼
function setCookie(name,value,time)
{
var strsec = getsec(time);
var exp = new Date();
exp.setTime(exp.getTime() + strsec*1);
document.cookie = name + "="+ escape ( value) + ";expires=" + exp.toGMTString();
}
function getsec(str)
{
alert(str);
var str1=str.substring(1 ,str.length)*1;
var str2=str.substring(0,1);
if (str2=="s")
{
return str1*1000;
}
else if (str2=="h")
{
return str1*60*60*1000;
}
else if (str2=="d")
{
return str1*24*60*60*1000;
}
}
//這是有設定過期時間的使用範例:
//s20是代表20秒
//h是指小時,如12小時則是:h12
//d是天數,30天則:d30
setCookie("name","hayden","s20");

 

#


封裝函數
#//取得
function getCookie(c_name){
if (document.cookie.length>0) {
  var c_start=document.cookie.indexOf( c_name + "=")
  //console.log(c_start);
  if(c_start!=-1){
  c_start=c_start + c_name.length+1
  }else{
return;
  }
  //使用者名稱
  // console.log(c_start);
c_end=document.cookie.indexOf(";",c_start)
console.log( c_end) ;
if (c_end==-1) {
c_end=document.cookie.length;
}    
return document.cookie.substring(c_start,c_end);
#   }else.cookie.substring(c_start,c_end);
#   }else {
  return ""
  }

}
//設定
function setCookie(c_name,value,expiredays){
var exdate=new Date()
exdate. setDate(exdate.getDate()+expiredays);
document.cookie=c_name+ "=" +value+";"+((expiredays==null) ? "" : ";expires="+exdate.toGMTString () )
}
//檢查
function checkCookie(){
var username=getCookie('username')
console.log(username);
if (username! =null && 使用者名稱!=""){
alert('歡迎再次'+使用者名稱+'!');
//setCookie("使用者名稱",使用者名稱,-1);
}else{
username=prompt('請輸入您的姓名:',"")
  if (username!=null && username!=""){
setCookie('username',username ,365)
}
}
}

onload=checkCookie();###

以上是瀏覽器儲存技術cookie、session的實例介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!