快速理解session/token/cookie

cookie

Web Application 一般以 HTTP 協(xié)議作為傳輸協(xié)議, 但 HTTP 協(xié)議是無狀態(tài)的. 也就是說 server-side 與 client-side 一旦數(shù)據(jù)交換完畢后坏瞄,兩者之間的連接就會被關(guān)閉. client-side 再次發(fā)送請求時, 需要建立新的連接, 這就意味著 server-side 和 client-side 兩者之間無法通過 HTTP 的連接來實(shí)現(xiàn) 會話跟蹤. 顯然, 這是不合理的, 因?yàn)檫@樣無法保證完成一次 Web Application 業(yè)務(wù)流程中所產(chǎn)生的若干次 請求/響應(yīng) 操作的原子性, 從而會導(dǎo)致業(yè)務(wù)邏輯混亂. cookie 就是為了解決這一問題所引入的 會話跟蹤機(jī)制.

實(shí)現(xiàn)原理: 由 server-side 為 client-side 發(fā)放一張通行證, 并以此來認(rèn)證 client-side 的身份(出于安全性的考慮, 這張通行證一般是臨時的). 而這些通行證就是 cookie, 本質(zhì)上 cookie 就是一小段文本信息, 里面包含了有如 session_id/login-status/token 等認(rèn)證相關(guān)數(shù)據(jù).

session

基于 session 的用戶認(rèn)證借助于請求體對象 req 中的 session 數(shù)據(jù)來完成.

實(shí)現(xiàn)原理: 當(dāng) client-side 請求 server-side 并通過身份認(rèn)證后, server-side 就會生成并保存身份認(rèn)證相關(guān)的 session 數(shù)據(jù), 并將對應(yīng)的 sesssion_id 寫入 cookie 然后再響應(yīng)到 client-side, client-side 會把 cookie 文件保存在本地. 此后, client-side 的所有請求都會附帶該 session_id, 以確定 server-side 是否存在對應(yīng)的 session 數(shù)據(jù)以及檢驗(yàn) session 數(shù)據(jù)中的 login-status. 如果存在且 login-status 為 True, 則證明 client-side 是被信任的, 無須再次認(rèn)證身份. 否則, 需要重新進(jìn)入身份認(rèn)證流程.

缺點(diǎn):

server-side 保存 session 數(shù)據(jù)會增加運(yùn)維和存儲開銷
因?yàn)橐粋€ session_id 只能被保存有對應(yīng) session 數(shù)據(jù)的 server-side 完成認(rèn)證, 所以在擁有多臺 server-side 集群架構(gòu)的場景中會降低其擴(kuò)展性.
如果原生 App 不具備 cookie 功能模塊, 就會加大其接入 session 認(rèn)證后端的難度.
簡而言之, session 有如用戶信息檔案表, 里面包含了用戶的認(rèn)證信息和登錄狀態(tài)等信息. 而 cookie 就是用戶通行證.

token

token(令牌) 由 uid+time+sign[+固定參數(shù)] 組成:

uid: 用戶唯一身份標(biāo)識
time: 當(dāng)前時間的時間戳
sign: 簽名, 使用 hash/encrypt 壓縮成定長的十六進(jìn)制字符串玖翅,以防止第三方惡意拼接
固定參數(shù)(可選): 將一些常用的固定參數(shù)加入到 token 中是為了避免重復(fù)查庫
由其組成可以看出, token 的認(rèn)證方式類似于臨時的證書簽名, 并且是一種 server-side 無狀態(tài)的認(rèn)證方式, 非常適合于 REST API 的場景. 所謂無狀態(tài)就是 server-side 并不會保存身份認(rèn)證相關(guān)的數(shù)據(jù), token 只被保存在 client-side 中的 cookie 或 localstorage(數(shù)據(jù)庫).

實(shí)現(xiàn)原理: 當(dāng) client-side 發(fā)送請求 server-side 并完成身份認(rèn)證后, server-side 會生成但不保存一個 token, 而是將 token 以 cookie 或其他形式響應(yīng)給 client-side. 此后 client-side 發(fā)送請求時都會在 Request-Header 中附帶 token, server-side 收到 token 后再分發(fā)給其他的 身份認(rèn)證服務(wù) 負(fù)責(zé)處理認(rèn)證相關(guān)的業(yè)務(wù). E.G. Openstack 中的 Keystone 項(xiàng)目會為整個云平臺提供身份認(rèn)證服務(wù).

缺點(diǎn):

因?yàn)?token 一般都是 hash/encrypt 的字符串, 所以會額外附加 加密/解密 的性能開銷
有些加密方式同樣存在安全隱患

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市姐霍,隨后出現(xiàn)的幾起案子悉盆,更是在濱河造成了極大的恐慌盯荤,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,539評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件焕盟,死亡現(xiàn)場離奇詭異秋秤,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評論 3 396
  • 文/潘曉璐 我一進(jìn)店門灼卢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來绍哎,“玉大人,你說我怎么就攤上這事鞋真〕缪撸” “怎么了?”我有些...
    開封第一講書人閱讀 165,871評論 0 356
  • 文/不壞的土叔 我叫張陵涩咖,是天一觀的道長海诲。 經(jīng)常有香客問我,道長抠藕,這世上最難降的妖魔是什么饿肺? 我笑而不...
    開封第一講書人閱讀 58,963評論 1 295
  • 正文 為了忘掉前任蒋困,我火速辦了婚禮盾似,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘雪标。我一直安慰自己零院,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,984評論 6 393
  • 文/花漫 我一把揭開白布村刨。 她就那樣靜靜地躺著告抄,像睡著了一般。 火紅的嫁衣襯著肌膚如雪嵌牺。 梳的紋絲不亂的頭發(fā)上打洼,一...
    開封第一講書人閱讀 51,763評論 1 307
  • 那天,我揣著相機(jī)與錄音逆粹,去河邊找鬼募疮。 笑死,一個胖子當(dāng)著我的面吹牛僻弹,可吹牛的內(nèi)容都是我干的阿浓。 我是一名探鬼主播,決...
    沈念sama閱讀 40,468評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼蹋绽,長吁一口氣:“原來是場噩夢啊……” “哼芭毙!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起卸耘,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤退敦,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后蚣抗,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體侈百,經(jīng)...
    沈念sama閱讀 45,850評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,002評論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了设哗。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片唱捣。...
    茶點(diǎn)故事閱讀 40,144評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖网梢,靈堂內(nèi)的尸體忽然破棺而出震缭,到底是詐尸還是另有隱情,我是刑警寧澤战虏,帶...
    沈念sama閱讀 35,823評論 5 346
  • 正文 年R本政府宣布拣宰,位于F島的核電站,受9級特大地震影響烦感,放射性物質(zhì)發(fā)生泄漏巡社。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,483評論 3 331
  • 文/蒙蒙 一手趣、第九天 我趴在偏房一處隱蔽的房頂上張望晌该。 院中可真熱鬧,春花似錦绿渣、人聲如沸朝群。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,026評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽姜胖。三九已至,卻和暖如春淀散,著一層夾襖步出監(jiān)牢的瞬間右莱,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,150評論 1 272
  • 我被黑心中介騙來泰國打工档插, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留慢蜓,地道東北人。 一個月前我還...
    沈念sama閱讀 48,415評論 3 373
  • 正文 我出身青樓阀捅,卻偏偏與公主長得像胀瞪,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子饲鄙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,092評論 2 355

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理凄诞,服務(wù)發(fā)現(xiàn),斷路器忍级,智...
    卡卡羅2017閱讀 134,672評論 18 139
  • 目錄Cookie機(jī)制什么是CookieCookie的不可跨域名性Unicode編碼:保存中文BASE64編碼:保存...
    Tomatoro閱讀 16,946評論 7 186
  • 會話(Session)跟蹤是Web程序中常用的技術(shù)帆谍,用來跟蹤用戶的整個會話。常用的會話跟蹤技術(shù)是Cookie與Se...
    chinariver閱讀 5,620評論 1 49
  • 本文已獨(dú)家授權(quán) 鴻洋( hongyangAndroid) 公眾號發(fā)布窖剑! 前言:新公司項(xiàng)目中使用到了Cookie坚洽,在...
    騎小豬看流星閱讀 33,413評論 27 261
  • 集五福大戰(zhàn)最熱鬧的時候,我用其中一張優(yōu)惠券買了份基金西土,漲勢甚是喜人讶舰,看著時機(jī)尚可又用壓歲錢另投多筆,小有收益需了。傳喜...
    doubleMrL閱讀 105評論 0 0