老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業(yè)提供網(wǎng)站建設(shè)、域名注冊(cè)、服務(wù)器等服務(wù)

expressexpress-session的使用小結(jié)

簡(jiǎn)介

創(chuàng)新互聯(lián)公司專(zhuān)業(yè)IDC數(shù)據(jù)服務(wù)器托管提供商,專(zhuān)業(yè)提供成都服務(wù)器托管,服務(wù)器租用,資陽(yáng)服務(wù)器托管資陽(yáng)服務(wù)器托管,成都多線(xiàn)服務(wù)器托管等服務(wù)器托管服務(wù)。

express-session是express中的一個(gè)處理session的中間件,可以說(shuō)是express中最常見(jiàn)的中間件之一了.

由于會(huì)話(huà)管理依賴(lài)cookie的使用,所以它的api中有很多用于控制cookie的部分.

總的來(lái)說(shuō)express-session有如下的特點(diǎn):

  • session管理(基本功能)
  • cookie簽名
  • 可替換持久儲(chǔ)存模塊

本文中使用的版本為1.15.6.

安裝

npm install express-session --save

引入&使用

const express = require('express');
const app = new express();
const expressSession = require('express-session');

// 使用express-session
app.use(expressSession({
  secret:'hello world',// cookie簽名 這個(gè)屬性是必須的 具體配置和`cookie-parser`一樣
  saveUninitialized:true, // 是否自動(dòng)初始化 默認(rèn)為true
  resave:false,// 當(dāng)用戶(hù)session無(wú)變化的時(shí)候依然自動(dòng)保存
  cookie:{ // cookie的信息具體操作和`cookie-parser`一樣
    maxAge:1800000// 30分鐘后過(guò)期
  },
  rolling:true// 每次請(qǐng)求的時(shí)候覆寫(xiě)cookie
}))

會(huì)話(huà)簡(jiǎn)介

在express-session文檔中有如下的一句說(shuō)明:

Note Session data is not saved in the cookie itself, just the session ID. Session data is stored server-side.

Session中包含的數(shù)據(jù)不會(huì)保存在cookie中,僅僅是在cookie中保存了一個(gè)SessionId而已.實(shí)際的session的數(shù)據(jù)保存在服務(wù)端.

簡(jiǎn)單理解就是一個(gè)Map,鍵對(duì)應(yīng)的是session id值保存在cookie中,值對(duì)應(yīng)的是用戶(hù)保存在服務(wù)端的數(shù)據(jù).

api介紹

參數(shù)

創(chuàng)建express-cookie參數(shù)基本分為兩種.

  • 針對(duì)于cookie的設(shè)置
  • 針對(duì)于express-session的設(shè)置

cookie設(shè)置一覽:

app.use(expressSession({
  secret:'hello world', // cookie 簽名必須有否則會(huì)報(bào)錯(cuò)
  cookie:{
    domain:<參數(shù)>,
    expires:<參數(shù)>,
    httpOnly:<參數(shù)>,
    path:<參數(shù)>,
    sameSite:<參數(shù)>,
    secure:<參數(shù)>,
    maxAge:1800000
  }
}));

而這些對(duì)應(yīng)的參數(shù)就是服務(wù)端對(duì)于cookie的寫(xiě)入?yún)?shù),至于各個(gè)參數(shù)是什么意思參考下面的文章:

https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Headers/Set-Cookie

express-session部分設(shè)置:

app.use(expressSession({
  secret:'hello world', // cookie 簽名必須有否則會(huì)報(bào)錯(cuò)
  genid:function (request) { // 用于替換掉默認(rèn)ID生成的函數(shù) 第一個(gè)參數(shù)為reqeust
    return '隨機(jī)id'
  },
  name:'connect.sid',// 每次響應(yīng)中向cookie中起始的內(nèi)容,默認(rèn)起始為`connect.sid`,
  proxy:true,// 對(duì)于cookie使用secure后,在傳遞的過(guò)程中相信反向代理服務(wù)器,默認(rèn)為undefined只相信正向代理
  resave:true,// 在一次會(huì)話(huà)中無(wú)論是否session被改變都會(huì)進(jìn)行強(qiáng)制的儲(chǔ)存
  rolling:true,// 在每次會(huì)話(huà)中的響應(yīng)中都覆寫(xiě)一次cookie,重置倒計(jì)時(shí)
  saveUninitialized:true,// 將一個(gè)新創(chuàng)建還未修改的會(huì)話(huà)進(jìn)行儲(chǔ)存,默認(rèn)為true
  store:object// 一個(gè)儲(chǔ)存對(duì)象,默認(rèn)使用的是`MemoryStore`這個(gè)存儲(chǔ)器
  unset:'keep'// 控制沒(méi)有設(shè)置`req.session`時(shí)候的行為(使用delete刪除或者賦值null),默認(rèn)'keep'會(huì)話(huà)期間不會(huì)保留,'destroy'會(huì)話(huà)完成后刪除.
}));

方法

request.session上掛載的session對(duì)象,除了有你添加的內(nèi)容外,還有默認(rèn)的方法存在:

req.session.regenerate(function(err) {
 // 調(diào)用這個(gè)方法從新生成一個(gè)新的會(huì)話(huà),完成后觸發(fā)
})
req.session.destroy(function(err) {
 // 刪除這個(gè)會(huì)話(huà),完成后觸發(fā)
})
req.session.reload(function(err) {
 // 從新加載session數(shù)據(jù),完成后觸發(fā)回調(diào)
})
req.session.save(function(err) {
 // 使用當(dāng)前內(nèi)存中的數(shù)據(jù)保存到儲(chǔ)存器中
 // 默認(rèn)在會(huì)話(huà)結(jié)束的時(shí)候就會(huì)自動(dòng)調(diào)用這個(gè)方法
})
req.session.touch() // 更新cookie中的maxAge,一般不需要手動(dòng)操作,交由中間件

屬性

同樣的在session實(shí)例上也有很多屬性:

req.session.id // 保存唯一的會(huì)話(huà)id值,不可修改
req.session.cookie // 以鍵值對(duì)的形式保存cookie的原始數(shù)據(jù)
req.session.cookie.maxAge // 以毫秒的形式返回剩余存活時(shí)間
req.sessionID // 保存唯一的會(huì)話(huà)id,只讀

一個(gè)簡(jiǎn)單的例子

一個(gè)簡(jiǎn)單的登錄例子:

const express = require('express');
const app = new express();
const expressSession = require('express-session');
const userDb = new Map();
app.use(expressSession({
  secret:'hello world',
  saveUninitialized:true,
  resave:false,
  cookie:{
    maxAge:1800000
  },
  rolling:true,
}));


app.get('/login', (request, response) => {

  const
    id = request.query.id,
    pwd = request.query.pwd;

  if(id && pwd){

    if(userDb.has(id+pwd)){

      response.send('該用戶(hù)已登錄');

    }else{

      request.session.userId = id+pwd;
      userDb.set(id+pwd,id);
      response.redirect('/');

    }

  }else{
    response.send('請(qǐng)輸入正確的帳號(hào)和密碼');
  }

});

app.get('/logout',(request, response)=>{

  const userId = request.session.userId;

  request.session.destroy((err)=>{

    if(err || !userDb.has(userId)){
      response.send('登出失敗');
    }else{
      userDb.delete(userId);
      response.send('登出成功');
    }

  });

});

app.get('/',(request, response)=>{
  if(request.session.userId && userDb.has(request.session.userId)){
    response.send(`歡迎回來(lái)${userDb.get(request.session.userId)}`);
  }else{

    response.send('還未登錄');
  }
});

app.use((request, response) => {
  response.send('404 not found');
});
app.listen(8888, '127.0.0.1');

在瀏覽器中依次輸入以下url來(lái)模擬登錄行為:

localhost:8888/
localhost:8888/login?id=ASCll&pwd=123456
localhost:8888/
localhost:8888/logout
localhost:8888/

暗坑

我在chrome瀏覽器下運(yùn)行上面的例子多次后發(fā)現(xiàn)一個(gè)問(wèn)題,瀏覽器會(huì)進(jìn)行預(yù)讀取網(wǎng)頁(yè)來(lái)提高性能,也就是說(shuō)在瀏覽器中當(dāng)我url輸入到如下的地方時(shí):

localhost:8888/logo

根據(jù)我之間多次進(jìn)入這個(gè)頁(yè)面瀏覽器會(huì)提前訪問(wèn)這個(gè)頁(yè)面localhost:8888/logout,而導(dǎo)致服務(wù)器直接刪除session等到真正進(jìn)入到頁(yè)面的時(shí)候已經(jīng)是第二次加載頁(yè)面了,導(dǎo)致每次登出都顯示失敗.

希望有經(jīng)驗(yàn)的朋友能給出一個(gè)合理的解決方案.

注意

當(dāng)express-sessioncookie-parser一起使用的時(shí)候?qū)τ?code>cookie的簽名必須一致.

express-session的存儲(chǔ)實(shí)例是可以更換的,默認(rèn)使用MemoryStore只適合于測(cè)試和開(kāi)發(fā)使用,生產(chǎn)環(huán)境必須要使用其他的儲(chǔ)存實(shí)例,否則會(huì)出現(xiàn)內(nèi)存碎片問(wèn)題,在官方文檔中給出了已經(jīng)實(shí)現(xiàn)的接口,可以對(duì)接redis以及MongoDB等數(shù)據(jù)庫(kù).

該列表在官方文檔的最后:

npm地址

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


網(wǎng)站題目:expressexpress-session的使用小結(jié)
文章位置:http://www.xueling.net.cn/article/ggspgd.html

其他資訊

在線(xiàn)咨詢(xún)
服務(wù)熱線(xiàn)
服務(wù)熱線(xiàn):028-86922220
TOP
主站蜘蛛池模板: 大内密探零零性在线 | 中文字幕在线观看国产推理片 | 久久久久久伊人高潮影院 | 中文日产幕无线码一区tr | 影音先锋成人影院 | 国产老肥熟精品大全 | 亚洲精品综合 | 久久精品亚洲人成影院 | 亚洲色欲色欲色欲www | 日韩精品一区二区三区色 | 国产裸拍裸体视频在线观看 | 国产精品白丝喷水在线观看 | 亚洲最大AV一区二区三区 | 亚洲午夜无码毛片av久久久久久 | 国产一级片不卡 | 色婷婷五月综合亚洲小说 | 伊人久久大线影院首页 | 福利社午夜影院 | 国产在线乱码一区二区三区 | 久久久久久久久网站 | 又大又黄又粗高潮免费 | 国产精品视频一二 | 国产喷水av | 亚洲无人区码一码二码三码的特点 | 久久高清亚洲 | 亚洲最大黄色片 | 国产成人午夜福利r在线观看观看 | 凤隐天下60集全免费播放在线观看 | aⅴ日本亚洲欧洲免费天堂 男生操女生视频在线观看 亚洲一久久久久久久久 | av无码专区亚洲av毛片 | 久久中文字幕一区 | 国产片性视频免费播放 | 日本三级日本三级韩国三级视 | 吉林小伟无套gay | 亚洲男女视频在线观看 | 免费看国产一级特黄aaaa大片 | 国产精品人妻无码一区二区三区 | 九九精品影院 | 女人色极品影院 | 日韩一区二区视频在线观看 | 午夜视频在线观看一区二区 |