node.js 中間件express-session使用詳解
本文介紹的關(guān)于node.js中間件express-session的相關(guān)內(nèi)容,分享出來(lái)供大家從參考學(xué)習(xí),下面來(lái)一起看看詳細(xì)的介紹:
一、為什么使用session?
session運(yùn)行在服務(wù)器端,當(dāng)客戶端第一次訪問(wèn)服務(wù)器時(shí),可以將客戶的登錄信息保存。
當(dāng)客戶訪問(wèn)其他頁(yè)面時(shí),可以判斷客戶的登錄狀態(tài),做出提示,相當(dāng)于登錄攔截。
session可以和Redis或者數(shù)據(jù)庫(kù)等結(jié)合做持久化操作,當(dāng)服務(wù)器掛掉時(shí)也不會(huì)導(dǎo)致某些客戶信息(購(gòu)物車)丟失。
二、session的工作流程:
當(dāng)瀏覽器訪問(wèn)服務(wù)器并發(fā)送第一次請(qǐng)求時(shí),服務(wù)器端會(huì)創(chuàng)建一個(gè)session對(duì)象,生成一個(gè)類似于key,value的鍵值對(duì), 然后將key(cookie)返回到瀏覽器(客戶)端,瀏覽器下次再訪問(wèn)時(shí),攜帶key(cookie),找到對(duì)應(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è)請(qǐng)求時(shí),其中一個(gè)請(qǐng)求在另一個(gè)請(qǐng)求結(jié)束時(shí)對(duì)session進(jìn)行修改覆蓋并保存。
默認(rèn)為true。但是(后續(xù)版本)有可能默認(rèn)失效,所以最好手動(dòng)添加。
saveUninitialized:初始化session時(shí)是否保存到存儲(chǔ)。默認(rèn)為true, 但是(后續(xù)版本)有可能默認(rèn)失效,所以最好手動(dòng)添加。
cookie:設(shè)置返回到前端key的屬性,默認(rèn)值為{ path: ‘/', httpOnly: true, secure: false, maxAge: null }
。
express-session的一些方法:
Session.destroy()
:刪除session,當(dāng)檢測(cè)到客戶端關(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,第一次請(qǐng)求時(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+',歡迎來(lái)到我的家園。'); }else{ res.send('你還沒有登錄,先登錄下再試試!'); } });
總結(jié)
好了,以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
使用Node.js的async和await進(jìn)行異步編程
使用異步編程可以提高Node.js應(yīng)用程序的性能,而async和await是Node.js中實(shí)現(xiàn)異步編程的一種簡(jiǎn)單且易于使用的方式,可以幫助開發(fā)者避免回調(diào)地獄和處理異步操作時(shí)的錯(cuò)誤2023-05-05使用Express處理請(qǐng)求和托管靜態(tài)資源方式
這篇文章主要介紹了使用Express處理請(qǐng)求和托管靜態(tài)資源方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09NodeJs環(huán)境中NODE_ENV介紹和設(shè)置方法
這篇文章主要給大家介紹了關(guān)于NodeJs環(huán)境中NODE_ENV介紹和設(shè)置的相關(guān)資料,NODE_ENV其實(shí)就是環(huán)境變量之一,用于設(shè)置nodejs當(dāng)前的運(yùn)行環(huán)境,需要的朋友可以參考下2024-07-07nodeJS與MySQL實(shí)現(xiàn)分頁(yè)數(shù)據(jù)以及倒序數(shù)據(jù)
這篇文章主要介紹了nodeJS與MySQL實(shí)現(xiàn)分頁(yè)數(shù)據(jù)以及倒序數(shù)據(jù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06Node.js之HTTP服務(wù)端和客戶端實(shí)現(xiàn)方式
這篇文章主要介紹了Node.js之HTTP服務(wù)端和客戶端實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-09-09Node.js中Sequelize?hook的使用方法小結(jié)
Sequelize?提供了多個(gè)?hook,用于在執(zhí)行數(shù)據(jù)庫(kù)操作時(shí)執(zhí)行一些自定義邏輯,本文為大家整理了一些常用的?Sequelize?hook?列表及其作用,希望對(duì)大家有所幫助2024-02-02安裝使用Mongoose配合Node.js操作MongoDB的基礎(chǔ)教程
這篇文章主要介紹了安裝使用Mongoose來(lái)讓Node.js操作MongoDB的基礎(chǔ)教程,前端js+后端node+js操作MongoDB正是所謂最流行的一種JavaScript全棧開發(fā)方案,需要的朋友可以參考下2016-03-03