nodejs 的 session 簡(jiǎn)單使用
session的本質(zhì)使用cookie來實(shí)現(xiàn)。
原理大概是:http 帶來服務(wù)端提前設(shè)置 cookie,服務(wù)端拿到標(biāo)示用戶身份的cookie, 再去固定地點(diǎn)(數(shù)據(jù)庫,文件)檢索出對(duì)應(yīng)的用戶身份。把身份賦值給本次請(qǐng)求的request,在程序處理中就知曉了用戶的身份了。(在PHP,ASP或者其他服務(wù)端語言中都自動(dòng)幫你實(shí)現(xiàn)了)
實(shí)現(xiàn)cookie
需要為每一個(gè)用戶設(shè)置一個(gè)可以標(biāo)示用戶身份的cookie??梢允褂萌缦乱?guī)則
注冊(cè)郵箱MD5值+密碼MD5值+隨機(jī)碼MD5值。(僅僅舉例,這可能并不是一個(gè)好的方案)
服務(wù)端代碼片段:
cookie
使用 cookie 獲取用戶身份,設(shè)置session
把所有非靜態(tài)資源的請(qǐng)求都定向到這里處理。獲取cookie,把cookie拆分并在數(shù)據(jù)庫查找符合條件的用戶。最后使用 next 跳轉(zhuǎn)到下一個(gè)請(qǐng)求邏輯。
下一個(gè)請(qǐng)求邏輯就可是直接使用 req.session.user 來獲取 user 對(duì)象了。
req.session = {};
if( req.cookies && req.cookies.sid ){
var a = req.cookies.sid.split("|");
var hexMail = a[0];
var hexPwd = a[1];
var hexRandom = a[2];
UserModel.hexFind(hexMail, hexPwd, hexRandom, function( status ){
//console.log("hexFind", status );
if(status.code == "0"){
//req.cookiesSelecter = cookiesSelecter;
req.session.user = status.result;
}
next();
});
}else{
next();
}
}
以上就是nodejs 的 session 簡(jiǎn)單使用的全部?jī)?nèi)容,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
node.js學(xué)習(xí)之?dāng)嘌詀ssert的使用示例
assert 模塊主要用于編寫程序的單元測(cè)試時(shí)使用,通過斷言可以提早發(fā)現(xiàn)和排查出錯(cuò)誤。下面這篇文章主要給大家介紹了關(guān)于node.js學(xué)習(xí)之?dāng)嘌詀ssert的相關(guān)資料,需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-09-09nodejs簡(jiǎn)單實(shí)現(xiàn)中英文翻譯
這篇文章主要介紹了nodejs簡(jiǎn)單實(shí)現(xiàn)中英文翻譯的方法和示例,雖然還存在著不小的問題,但是也算是基本能用了,這里推薦給大家。2015-05-05node+koa2+mysql+bootstrap搭建一個(gè)前端論壇
本篇文章通過實(shí)例給大家分享了用node+koa2+mysql+bootstrap搭建一個(gè)前端論壇的步驟,有需要的朋友參考下。2018-05-05node操作mysql數(shù)據(jù)庫實(shí)例詳解
這篇文章主要介紹了node操作mysql數(shù)據(jù)庫,結(jié)合實(shí)例形式較為詳細(xì)的分析了node操作數(shù)據(jù)庫的連接、增刪改查、事務(wù)處理及錯(cuò)誤處理相關(guān)操作技巧,需要的朋友可以參考下2017-03-03Node.JS枚舉統(tǒng)計(jì)當(dāng)前文件夾和子目錄下所有代碼文件行數(shù)
這篇文章主要介紹了Node.JS枚舉統(tǒng)計(jì)當(dāng)前文件夾和子目錄下所有代碼文件行數(shù),本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08