node.js 中間件express-session使用詳解
本文介紹的關(guān)于node.js中間件express-session的相關(guān)內(nèi)容,分享出來供大家從參考學(xué)習(xí),下面來一起看看詳細的介紹:
一、為什么使用session?
session運行在服務(wù)器端,當客戶端第一次訪問服務(wù)器時,可以將客戶的登錄信息保存。
當客戶訪問其他頁面時,可以判斷客戶的登錄狀態(tài),做出提示,相當于登錄攔截。
session可以和Redis或者數(shù)據(jù)庫等結(jié)合做持久化操作,當服務(wù)器掛掉時也不會導(dǎo)致某些客戶信息(購物車)丟失。
二、session的工作流程:
當瀏覽器訪問服務(wù)器并發(fā)送第一次請求時,服務(wù)器端會創(chuàng)建一個session對象,生成一個類似于key,value的鍵值對, 然后將key(cookie)返回到瀏覽器(客戶)端,瀏覽器下次再訪問時,攜帶key(cookie),找到對應(yīng)的session(value) 。 客戶的信息都保存在session中。
三、express-session的常用參數(shù):
secret:一個String類型的字符串,作為服務(wù)器端生成session的簽名。
name:返回客戶端的key的名稱,默認為connect.sid,也可以自己設(shè)置。
resave:(是否允許)當客戶端并行發(fā)送多個請求時,其中一個請求在另一個請求結(jié)束時對session進行修改覆蓋并保存。
默認為true。但是(后續(xù)版本)有可能默認失效,所以最好手動添加。
saveUninitialized:初始化session時是否保存到存儲。默認為true, 但是(后續(xù)版本)有可能默認失效,所以最好手動添加。
cookie:設(shè)置返回到前端key的屬性,默認值為{ path: ‘/', httpOnly: true, secure: false, maxAge: null } 。
express-session的一些方法:
Session.destroy() :刪除session,當檢測到客戶端關(guān)閉時調(diào)用。
Session.reload() :當session有修改時,刷新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,第一次請求時我們保存一條用戶信息。
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('你還沒有登錄,先登錄下再試試!');
}
});
總結(jié)
好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
nodejs16.15.0版本如何解決node-sass和sass-loader版本沖突問題
這篇文章主要介紹了nodejs16.15.0版本如何解決node-sass和sass-loader版本沖突問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
這篇文章主要介紹了node中Stream的詳細介紹,流是一個數(shù)據(jù)傳輸手段,是端到端信息交換的一種方式,而且是有順序的,是逐塊讀取數(shù)據(jù)、處理內(nèi)容,用于順序讀取輸入或?qū)懭胼敵?/div> 2022-09-09
Node.js+Express+MySql實現(xiàn)用戶登錄注冊功能
這篇文章主要為大家詳細介紹了Node.js+Express+MySql實現(xiàn)用戶登錄注冊,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07最新評論

