一烁涌、Cookie、session和localStorage的區(qū)別
cookie的內(nèi)容主要包括:名字酒觅、值烹玉、過(guò)期時(shí)間、路徑和域阐滩。路徑與域一起構(gòu)成cookie的作用范圍二打。若不設(shè)置時(shí)間,則表示這個(gè)cookie的生命期為瀏覽器會(huì)話期間掂榔,關(guān)閉瀏覽器窗口继效,cookie就會(huì)消失症杏。這種生命期為瀏覽器會(huì)話期的cookie被稱為會(huì)話cookie。?
會(huì)話cookie一般不存儲(chǔ)在硬盤而是保存在內(nèi)存里瑞信,當(dāng)然這個(gè)行為并不是規(guī)范規(guī)定的厉颤。若設(shè)置了過(guò)期時(shí)間,瀏覽器就會(huì)把cookie保存到硬盤上凡简,關(guān)閉后再打開瀏覽器這些cookie仍然有效直到超過(guò)設(shè)定的過(guò)期時(shí)間逼友。對(duì)于保存在內(nèi)存里的cookie,不同的瀏覽器有不同的處理方式session機(jī)制秤涩。?
當(dāng)程序需要為某個(gè)客戶端的請(qǐng)求創(chuàng)建一個(gè)session時(shí)帜乞,服務(wù)器首先檢查這個(gè)客戶端的請(qǐng)求里是否已包含了一個(gè)session標(biāo)識(shí)(稱為session id),如果已包含則說(shuō)明以前已經(jīng)為此客戶端創(chuàng)建過(guò)session筐眷,服務(wù)器就按照session id把這個(gè)session檢索出來(lái)使用(檢索不到黎烈,會(huì)新建一個(gè)),如果客戶端請(qǐng)求不包含session id匀谣,則為客戶端創(chuàng)建一個(gè)session并且生成一個(gè)與此session相關(guān)聯(lián)的session id照棋,session id的值應(yīng)該是一個(gè)既不會(huì)重復(fù),又不容易被找到規(guī)律以仿造的字符串武翎,這個(gè)session id將被在本次響應(yīng)中返回給客戶端保存烈炭。保存這個(gè)session id的方式可以采用cookie,這樣在交互過(guò)程中瀏覽器可以自動(dòng)的按照規(guī)則把這個(gè)標(biāo)識(shí)發(fā)送給服務(wù)器宝恶。
二梳庆、cookie和session的區(qū)別:?
1、cookie數(shù)據(jù)存放在客戶的瀏覽器上卑惜,session數(shù)據(jù)放在服務(wù)器上?
2膏执、cookie不是很安全,別人可以分析存放在本地的cookie并進(jìn)行cookie欺騙露久,考慮*到安全應(yīng)當(dāng)使用session?
3更米、session會(huì)在一定時(shí)間內(nèi)保存在服務(wù)器上,當(dāng)訪問(wèn)增多毫痕,會(huì)比較占用你服務(wù)器的性能征峦,考慮到減輕服務(wù)器性能方面,應(yīng)當(dāng)使用cookie?
4消请、單個(gè)cookie保存的數(shù)*據(jù)不能超過(guò)4K栏笆,很多瀏覽器都限制一個(gè)站點(diǎn)最多保存20個(gè)cookie?
5、建議將登錄信息等重要信息存放為session臊泰,其他信息如果需要保留蛉加,可以放在cookie中?
6、session保存在服務(wù)器,客戶端不知道其中的信心针饥;cookie保存在客戶端厂抽,服務(wù)器能夠知道其中的信息?
7、session中保存的是對(duì)象丁眼,cookie中保存的是字符串?
8筷凤、session不能區(qū)分路徑,同一個(gè)用戶在訪問(wèn)一個(gè)網(wǎng)站期間苞七,所有的session在任何一個(gè)地方都可以訪問(wèn)到藐守,而cookie中如果設(shè)置了路徑參數(shù),那么同一個(gè)網(wǎng)站中不同路徑下的cookie互相是訪問(wèn)不到的*
三蹂风、web Storage和Cookie的區(qū)別?
Web Storage的概念和cookie相似卢厂,區(qū)別是它是為了更大容量存儲(chǔ)設(shè)計(jì)的,cookie的大小是受限的硫眨,并且每次請(qǐng)求一個(gè)新的頁(yè)面的時(shí)候cookie都會(huì)被發(fā)送過(guò)去,這樣無(wú)形中浪費(fèi)了帶寬巢块,另外cookie還需要指定作用域礁阁,不可跨域調(diào)用。?
除此之外族奢,web storage擁有setItem,getItem,removeItem,clear等方法姥闭,不像cookie需要前端開發(fā)者自己封裝setCookie,getCookie越走。?
但是cookie也是不可或缺的棚品,cookie的作用是與服務(wù)器進(jìn)行交互,作為http規(guī)范的一部分而存在的廊敌,而web Storage僅僅是為了在本地“存儲(chǔ)”數(shù)據(jù)而生?
sessionStorage铜跑、localStorage、cookie都是在瀏覽器端存儲(chǔ)的數(shù)據(jù)骡澈,其中sessionStorage的概念很特別锅纺,引入了一個(gè)“瀏覽器窗口”的概念,sessionStorage是在同源的同窗口中肋殴,始終存在的數(shù)據(jù)囤锉,也就是說(shuō)只要這個(gè)瀏覽器窗口沒(méi)有關(guān)閉,即使刷新頁(yè)面或進(jìn)入同源另一個(gè)頁(yè)面护锤,數(shù)據(jù)仍然存在官地,關(guān)閉窗口后,sessionStorage就會(huì)被銷毀烙懦,同時(shí)“獨(dú)立”打開的不同窗口驱入,即使是同一頁(yè)面,sessionStorage對(duì)象也是不同的
Web Storage帶來(lái)的好處:?
1、減少網(wǎng)絡(luò)流量:一旦數(shù)據(jù)保存在本地之后沧侥,就可以避免再向服務(wù)器請(qǐng)求數(shù)據(jù)可霎,因此減少不必要的數(shù)據(jù)請(qǐng)求,減少數(shù)
據(jù)在瀏覽器和服務(wù)器間不必要的來(lái)回傳遞?
2宴杀、快速顯示數(shù)據(jù):性能好癣朗,從本地讀數(shù)據(jù)比通過(guò)網(wǎng)絡(luò)從服務(wù)器上獲得數(shù)據(jù)快得多,本地?cái)?shù)據(jù)可以及時(shí)獲得旺罢,再加上網(wǎng)
頁(yè)本身也可以有緩存旷余,因此整個(gè)頁(yè)面和數(shù)據(jù)都在本地的話,可以立即顯示?
3扁达、臨時(shí)存儲(chǔ):很多時(shí)候數(shù)據(jù)只需要在用戶瀏覽一組頁(yè)面期間使用正卧,關(guān)閉窗口后數(shù)據(jù)就可以丟棄了,這種情況使用sessionStorage非常方便
四跪解、瀏覽器本地存儲(chǔ)與服務(wù)器端存儲(chǔ)的區(qū)別?
其實(shí)數(shù)據(jù)既可以在瀏覽器本地存儲(chǔ)炉旷,也可以在服務(wù)器端存儲(chǔ)?
瀏覽器可以保存一些數(shù)據(jù),需要的時(shí)候直接從本地存取叉讥,sessionStorage窘行、localStorage和cookie都是由瀏覽器存儲(chǔ)在本地的數(shù)據(jù)?
服務(wù)器端也可以保存所有用戶的所有數(shù)據(jù),但需要的時(shí)候?yàn)g覽器要向服務(wù)器請(qǐng)求數(shù)據(jù)图仓。?
1罐盔、服務(wù)器端可以保存用戶的持久數(shù)據(jù),如數(shù)據(jù)庫(kù)和云存儲(chǔ)將用戶的大量數(shù)據(jù)保存在服務(wù)器端?
2救崔、服務(wù)器端也可以保存用戶的臨時(shí)會(huì)話數(shù)據(jù)惶看,服務(wù)器端的session機(jī)制,如jsp的session對(duì)象六孵,數(shù)據(jù)保存在服務(wù)器上纬黎,
實(shí)際上,服務(wù)器和瀏覽器之間僅需傳遞session id即可劫窒,服務(wù)器根據(jù)session id找到對(duì)應(yīng)用戶的session對(duì)象莹桅,會(huì)話數(shù)據(jù)僅在一段時(shí)間內(nèi)有效,這個(gè)時(shí)間就是server端設(shè)置的session有效期
服務(wù)器端保存所有的用戶的數(shù)據(jù)烛亦,所以服務(wù)器端的開銷較大诈泼,而瀏覽器端保存則把不同用戶需要的數(shù)據(jù)分別保存在用戶各自的瀏覽器中,瀏覽器端一般只用來(lái)存儲(chǔ)小數(shù)據(jù)煤禽,而非服務(wù)可以存儲(chǔ)大數(shù)據(jù)或小數(shù)據(jù)服務(wù)器存儲(chǔ)數(shù)據(jù)安全一些铐达,瀏覽器只適合存儲(chǔ)一般數(shù)據(jù)
五、sessionStorage檬果、localStorage和cookie的區(qū)別?
共同點(diǎn):都是保存在瀏覽器端瓮孙、且同源的?
區(qū)別:?
1唐断、cookie數(shù)據(jù)始終在同源的http請(qǐng)求中攜帶(即使不需要),即cookie在瀏覽器和服務(wù)器間來(lái)回傳遞杭抠,而sessionStorage和localStorage不會(huì)自動(dòng)把數(shù)據(jù)發(fā)送給服務(wù)器脸甘,僅在本地保存。cookie數(shù)據(jù)還有路徑(path)的概念偏灿,可以限制cookie只屬于某個(gè)路徑下?
2丹诀、存儲(chǔ)大小限制也不同,cookie數(shù)據(jù)不能超過(guò)4K翁垂,同時(shí)因?yàn)槊看蝖ttp請(qǐng)求都會(huì)攜帶cookie铆遭、所以cookie只適合保存很小的數(shù)據(jù),如會(huì)話標(biāo)識(shí)沿猜。sessionStorage和localStorage雖然也有存儲(chǔ)大小的限制枚荣,但比cookie大得多,可以達(dá)到5M或更大?
3啼肩、數(shù)據(jù)有效期不同橄妆,sessionStorage:僅在當(dāng)前瀏覽器窗口關(guān)閉之前有效;localStorage:始終有效祈坠,窗口或?yàn)g覽器關(guān)閉也一直保存害碾,因此用作持久數(shù)據(jù);cookie:只在設(shè)置的cookie過(guò)期時(shí)間之前有效颁虐,即使窗口關(guān)閉或?yàn)g覽器關(guān)閉?
4蛮原、作用域不同卧须,sessionStorage不在不同的瀏覽器窗口中共享另绩,即使是同一個(gè)頁(yè)面;localstorage在所有同源窗口中都是共享的花嘶;cookie也是在所有同源窗口中都是共享的?
5笋籽、web Storage支持事件通知機(jī)制,可以將數(shù)據(jù)更新的通知發(fā)送給監(jiān)聽(tīng)者?
6椭员、web Storage的api接口使用更方便
六车海、sessionStorage與頁(yè)面js數(shù)據(jù)對(duì)象的區(qū)別
頁(yè)面中一般的js對(duì)象的生存期僅在當(dāng)前頁(yè)面有效,因此刷新頁(yè)面或轉(zhuǎn)到另一頁(yè)面這樣的重新加載頁(yè)面的情況隘击,數(shù)據(jù)就不存在了?
而sessionStorage只要同源的同窗口中侍芝,刷新頁(yè)面或進(jìn)入同源的不同頁(yè)面,數(shù)據(jù)始終存在埋同,也就是說(shuō)只要瀏覽器不關(guān)閉州叠,數(shù)據(jù)仍然存在