nodejs中使用session的說明。前端
爲何使用session:node
session運行在服務器端,當客戶端第一次訪問服務器時,能夠將客戶的登錄信息保存。git
當客戶訪問其餘界面時,能夠判斷客戶的登錄狀態,作出提示。github
能夠保存一些客戶的經常使用信息,當客戶端再次獲取經常使用信息時,沒必要再從數據庫中進行查詢。redis
session能夠與redis或數據庫等結合作持久化操做,當服務器掛掉時也不會致使某些客戶信息(購物車)消失。數據庫
session的工做流程:express
當瀏覽器訪問服務器併發送第一次請求時,服務器端會建立一個session對象,生成一個相似於key,value的鍵值對,api
而後將key(cookie)返回到瀏覽器(客戶)端,瀏覽器下次再訪問時,攜帶key(cookie),找到對應的session(value)。瀏覽器
客戶的信息都保存在session中。服務器
nodejs中經過express-session來操做和使用session。
GitHub上地址:https://github.com/expressjs/session
express-session的經常使用參數:
secret:一個String類型的字符串,做爲服務器端生成session的簽名。
name:返回客戶端的key的名稱,默認爲connect.sid,也能夠本身設置。
resave:(是否容許)當客戶端並行發送多個請求時,其中一個請求在另外一個請求結束時對session進行修改覆蓋並保存。
默認爲true。可是(後續版本)有可能默認失效,因此最好手動添加。
saveUninitialized:初始化session時是否保存到存儲。默認爲true, 可是(後續版本)有可能默認失效,因此最好手動添加。
cookie:設置返回到前端key的屬性,默認值爲{ path: '/', httpOnly: true, secure: false, maxAge: null }。
express-session的一些方法:
Session.destroy():刪除session,當檢測到客戶端關閉時調用。
Session.reload():當session有修改時,刷新session。
Session.regenerate():將已有session初始化。
Session.save():保存session。
3.示例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('你尚未登陸,先登陸下再試試!'); } });
第一次訪問http://localhost:3000/users時,會提示沒有登錄,訪問http://localhost:3000/後再訪問,則顯示用戶信息。
4.其餘說明
學習使用session時,在網上找了大部分文章,說的都比較籠統,因此本身整理了一篇。
文中一些方法參數,是本人查看api後,我的理解,可能會有所誤差,歡迎隨時提問、補充。
網上查閱過程當中以爲寫得很好的文章,來自alsotang,GitHub地址:https://github.com/alsotang/node-lessons/tree/master/lesson16