nodejs cookie與session

来源:http://www.cnblogs.com/gxp69/archive/2017/07/25/7236217.html
-Advertisement-
Play Games

cookie、session cookie:在瀏覽器保存一些數據,每次請求都會帶過來 *不安全、有限(4K) session:保存數據,保存在服務端 *安全、無限 session:基於cookie實現的 *cookie中會有一個session的ID,伺服器利用sessionid找到session文件 ...


cookie、session

cookie:在瀏覽器保存一些數據,每次請求都會帶過來
*不安全、有限(4K)

session:保存數據,保存在服務端
*安全、無限

--------------------------------------------------------------------------------------------------------------

session:基於cookie實現的
*cookie中會有一個session的ID,伺服器利用sessionid找到session文件、讀取、寫入

隱患:session劫持

cookie:

1.cookie空間非常小——省著用

2.安全性非常差——校驗cookie是否被篡改過

用法:

a.發送cookie

res.secret='字元串';  //秘鑰,對cookie加密
res.cookie(名字, 值, {path: '/', maxAge: 毫秒, signed: true});
// path:路徑,maxAge:過期時間,signed:是否加密

b.讀取cookie

cookie-parser中間件
server.use(cookieParser('秘鑰'));
server.use(function (){
  req.cookies    未簽名版
  req.signedCookies    簽名版
});

c.刪除cookie

res.clearCookie(名字);

舉例:

const express=require('express');
const cookieParser=require('cookie-parser');

var server=express();

//cookie
server.use(cookieParser('wesdfw4r34tf'));

server.use('/', function (req, res){
  req.secret='wesdfw4r34tf';
  res.cookie('user', 'blue', {signed: true});

  console.log('簽名cookie:', req.signedCookies)
  console.log('無簽名cookie:', req.cookies);
 //res.clearCookie('user');
res.send('ok'); }); server.listen(8080);

session:

cookie-session中間件

cookieSession(options)

name

要設置的Cookie的名稱,預設為session

keys

用於簽署和驗證Cookie值的鍵列表。

secret

如果keys沒有提供,將用該字元串做標記

Cookie Options

其他選項傳遞給 cookies.get() 和 cookies.set() ,允許你控制secure、path、domain,並簽署其他設置。

這些選項還可以包含以下任何內容(有關完整列表,請參閱 cookies模塊文檔

  • maxAge:表示Date.now()到期的毫秒數
  • expiresDate指示Cookie過期日期對象(預設情況下在會話結束時過期)。
  • path:指示cookie路徑的字元串(/預設情況下)。
  • domain:表示cookie的域的字元串(無預設)。
  • sameSite:一個布爾值或字元串,指示cookie是否為“相同站點”cookie(false預設情況下)。這可以設置為'strict',,'lax'true(映射到'strict')。
  • secure:一個布爾值,指示cookie是否僅通過HTTPS發送(false預設為HTTP true預設情況下為HTTPS)。如果這樣設置,true並且Node.js不是直接通過TLS連接,請務必閱讀如何在代理之後設置Express,否則Cookie可能無法正確設置。
  • httpOnly:一個布爾值,表示cookie是否僅通過HTTP(S)發送,並且不提供給客戶端JavaScript(true預設情況下)。
  • signed:一個布爾值,表示cookie是否要被簽名(true預設情況下)。如果是這樣的話,.sig還會發送一個帶附加尾碼的同名的另一個cookie ,一個27位元組的url-safe base64 SHA1值代表第一個Keygripcookie-name = cookie-value的哈希此簽名密鑰用於在下次接收到Cookie時檢測篡改。
  • overwrite:一個布爾值,表示是否覆蓋以前設置的相同名稱的cookie(true預設情況下)。如果這是真的,在設置此Cookie時,將在同一請求中設置相同名稱的所有Cookie(不管路徑或域)是否從Set-Cookie頭部中過濾掉
 

1.寫入

server.use(cookieParser());
server.use(cookieSession({
  keys: [.., .., .., ..]
}));

2.讀取

server.use('/', function (){
  req.session
});

2.刪除

delete req.session
req.session = null

舉例:

const express=require('express');
const cookieParser=require('cookie-parser');
const cookieSession=require('cookie-session');

var server=express();

//cookie
server.use(cookieParser());
server.use(cookieSession({
  name: 'sess',
  keys: ['aaa', 'bbb', 'ccc'],
  maxAge: 2*3600*1000
}));

server.use('/', function (req, res){
  if(req.session['count']==null){
    req.session['count']=1;
  }else{
    req.session['count']++;
  }

  console.log(req.session);

  res.send('ok');
});

server.listen(8080);

 

--------------------------------------------------------------------------------------------------------------

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 設計模式(0)簡單工廠模式 設計模式(1)單例模式(Singleton) 設計模式(2)工廠方法模式(Factory Method) 源碼地址 0 抽象工廠模式簡介 0.0 抽象工廠模式定義 抽象工廠模式一般的書面定義為:提供一個創建一系列相關或相互依賴對象的介面,而無需指定他們具體的類 提供創建接 ...
  • 在介紹restful之前先放一張從之前文章評論里看到的圖,我覺得它把soap和rest之間的一些區別形容地非常形象。 在第一篇和第二篇中我們也介紹過,soap協議傳遞的報文要基於xml格式的soap消息,它定義了非常複雜的xml schemas,因此會讓傳遞的消息變得非常重,而rest是充分利用了h ...
  • 一、nginx Nginx (發音同 engine x)是一款輕量級的Web 伺服器/反向代理伺服器及電子郵件(IMAP/POP3)代理伺服器,併在一個BSD-like 協議下發行。 其特點是占有記憶體少,併發能力強,事實上nginx的併發能力確實在同類型的網頁伺服器中表現較好。目前中國大陸使用ngi ...
  • 相同點 兩者都用於在網頁載入完後執行相應代碼塊。 不同點 window.onload 在創建完 DOM 樹後,所有外部資源(圖片、Flash 動畫等)載入完成,且整個頁面在瀏覽器視窗中顯示完畢之後,才會執行。 $(document).ready 只需在 HTML 文檔解析為 DOM 樹後,就會執行。 ...
  • 用vue-cli生成項目時,如果選擇了單元測試,那麼會採用karma+mocha作為單元測試框架,預設使用的瀏覽器是PhantomJs。 Karma是一個基於Node.js的JavaScript測試執行過程管理工具(Test Runner)。可啟動所有主流Web瀏覽器作為測試容器,運行時會啟動一個w ...
  • 通過jQuery思維導圖,來進行計劃的溫習/掌握 jQuery技能。 通過思維導圖的思路學習,是很好的學習方法之一,思路清晰、跟上環節,易於貫通,重要的是少走彎路。 這裡一共有6張圖,第1張是大綱路線,順著路線可以掌握jQuery常用的操作,後面5張是關於jQuery相關Api及性能優化的細節。 結 ...
  • 一 HTML 是一種製作網站的標記語言 二、HTML基本語法 html標簽是html中的最基本單位 也是最重要的部分 通常使用尖角號 開始”<”和結束”>” 標簽分為兩種(成對出現 和不成 對出現) 雙標簽:(成對)<標簽名>內容</標簽名> 例如:<body></body><html></html ...
  • 冒泡排序<script type="text/javascript"> var arr = [3,7,6,2,1,5]; 定義一個交換使用的中間變數var temp = 0;for(i=0;i<arr.length;i++){ for(j=0;j<arr.length;j++){如果下一個元素小於當 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...