本文介紹的關(guān)于node.js中間件express-session的相關(guān)內(nèi)容,分享出來供大家從參考學(xué)習(xí),下面來一起看看詳細(xì)的介紹:
一、為什么使用session?
session運(yùn)行在服務(wù)器端,當(dāng)客戶端第一次訪問服務(wù)器時(shí),可以將客戶的登錄信息保存。
當(dāng)客戶訪問其他頁面時(shí),可以判斷客戶的登錄狀態(tài),做出提示,相當(dāng)于登錄攔截。
session可以和Redis或者數(shù)據(jù)庫等結(jié)合做持久化操作,當(dāng)服務(wù)器掛掉時(shí)也不會導(dǎo)致某些客戶信息(購物車)丟失。
二、session的工作流程:
當(dāng)瀏覽器訪問服務(wù)器并發(fā)送第一次請求時(shí),服務(wù)器端會創(chuàng)建一個(gè)session對象,生成一個(gè)類似于key,value的鍵值對, 然后將key(cookie)返回到瀏覽器(客戶)端,瀏覽器下次再訪問時(shí),攜帶key(cookie),找到對應(yīng)的session(value) 。 客戶的信息都保存在session中。
三、express-session的常用參數(shù):
secret:一個(gè)String類型的字符串,作為服務(wù)器端生成session的簽名。
name:返回客戶端的key的名稱,默認(rèn)為connect.sid,也可以自己設(shè)置。
resave:(是否允許)當(dāng)客戶端并行發(fā)送多個(gè)請求時(shí),其中一個(gè)請求在另一個(gè)請求結(jié)束時(shí)對session進(jìn)行修改覆蓋并保存。
默認(rèn)為true。但是(后續(xù)版本)有可能默認(rèn)失效,所以最好手動添加。
saveUninitialized:初始化session時(shí)是否保存到存儲。默認(rèn)為true, 但是(后續(xù)版本)有可能默認(rèn)失效,所以最好手動添加。
cookie:設(shè)置返回到前端key的屬性,默認(rèn)值為{ path: ‘/', httpOnly: true, secure: false, maxAge: null } 。
express-session的一些方法:
Session.destroy() :刪除session,當(dāng)檢測到客戶端關(guān)閉時(shí)調(diào)用。
Session.reload() :當(dāng)session有修改時(shí),刷新session。
Session.regenerate() :將已有session初始化。
Session.save() :保存session。
四、示例demo
//app.js中添加如下代碼(已有的不用添加)var express = require('express');var cookieParser = require('cookie-parser');var session = require('express-session');app.use(cookieParser('sessiontest'));app.use(session({ secret: 'sessiontest',//與cookieParser中的一致 resave: true, saveUninitialized:true}));//修改router/index.js,第一次請求時(shí)我們保存一條用戶信息。router.get('/', function(req, res, next) { var user={ name:"Chen-xy", age:"22", address:"bj" } req.session.user=user; res.render('index', { title: 'the test for nodejs session' , name:'sessiontest' });});//修改router/users.js,判斷用戶是否登陸。router.get('/', function(req, res, next) { if(req.session.user){ var user=req.session.user; var name=user.name; res.send('你好'+name+',歡迎來到我的家園。'); }else{ res.send('你還沒有登錄,先登錄下再試試!'); }});
新聞熱點(diǎn)
疑難解答
圖片精選