亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

深入剖析Express cookie-parser中間件實現示例

2024-05-06 16:42:13
字體:
來源:轉載
供稿:網友

文章導讀

cookie-parser 是Express的中間件,用來實現cookie的解析,是官方腳手架內置的中間件之一。

它的使用非常簡單,但在使用過程中偶爾也會遇到問題。一般都是因為對 Express + cookie-parser 的簽名、驗證機制不了解導致的。

本文深入講解 Express + cookie-parser 的簽名和驗證的實現機制,以及cookie簽名是如何增強網站的安全性的。

文本同步收錄于GitHub主題系列 《Nodejs學習筆記》

入門例子:cookie設置與解析

先從最簡單的例子來看下 cookie-parser 的使用,這里采用默認配置。

  1. cookie設置:使用 Express 的內置方法 res.cookie() 。
  2. cookie解析:使用 cookie-parser 中間件。
var express = require('express');var cookieParser = require('cookie-parser');var app = express();app.use(cookieParser());app.use(function (req, res, next) { console.log(req.cookies.nick); // 第二次訪問,輸出chyingp next();});app.use(function (req, res, next) {  res.cookie('nick', 'chyingp'); res.end('ok');});app.listen(3000);

在當前場景下, cookie-parser 中間件大致實現如下:

app.use(function (req, res, next) { req.cookies = cookie.parse(req.headers.cookie); next();});

進階例子:cookie簽名與解析

出于安全的考慮,我們通常需要對cookie進行簽名。

例子改寫如下,有幾個注意點:

  1. cookieParser 初始化時,傳入 secret 作為簽名的秘鑰。
  2. 設置cookie時,將 signed 設置為 true ,表示對即將設置的cookie進行簽名。
  3. 獲取cookie時,可以通過 req.cookies ,也可以通過 req.signedCookies 獲取。
var express = require('express');var cookieParser = require('cookie-parser');var app = express();// 初始化中間件,傳入的第一個參數為singed secretapp.use(cookieParser('secret'));app.use(function (req, res, next) { console.log(req.cookies.nick); // chyingp console.log(req.signedCookies.nick); // chyingp next();});app.use(function (req, res, next) {  // 傳入第三個參數 {signed: true},表示要對cookie進行摘要計算 res.cookie('nick', 'chyingp', {signed: true}); res.end('ok');});app.listen(3000);

簽名前的cookie值為 chyingp ,簽名后的cookie值為 s%3Achyingp.uVofnk6k%2B9mHQpdPlQeOfjM8B5oa6mppny9d%2BmG9rD0 ,decode后為 s:chyingp.uVofnk6k+9mHQpdPlQeOfjM8B5oa6mppny9d+mG9rD0 。

下面就來分析下,cookie的簽名、解析是如何實現的。

cookie簽名、驗證實現剖析

Express完成cookie值的簽名, cookie-parser 實現簽名cookie的解析。兩者共用同一個秘鑰。

cookie簽名

Express對cookie的設置(包括簽名),都是通過 res.cookie() 這個方法實現的。

精簡后的代碼如下:

res.cookie = function (name, value, options) {  var secret = this.req.secret; var signed = opts.signed; // 如果 options.signed 為true,則對cookie進行簽名 if (signed) {  val = 's:' + sign(val, secret); } this.append('Set-Cookie', cookie.serialize(name, String(val), opts)); return this;};

sign 為簽名函數。偽代碼如下,其實就是把cookie的原始值,跟hmac后的值拼接起來。

敲黑板劃重點:簽名后的cookie值,包含了原始值。

function sign (val, secret) { return val + '.' + hmac(val, secret);}

這里的 secret 哪來的呢?是 cookie-parser 初始化的時候傳入的。如下偽代碼所示:

var cookieParser = function (secret) { return function (req, res, next) {  req.secret = secret;  // ...  next(); };};app.use(cookieParser('secret'));

簽名cookie解析

知道了cookie簽名的機制后,如何"解析"簽名cookie就很清楚了。這個階段,中間件主要做了兩件事:

  1. 將簽名cookie對應的原始值提取出來
  2. 驗證簽名cookie是否合法

實現代碼如下:

// str:簽名后的cookie,比如 "s:chyingp.uVofnk6k+9mHQpdPlQeOfjM8B5oa6mppny9d+mG9rD0"// secret:秘鑰,比如 "secret"function signedCookie(str, secret) { // 檢查是否 s: 開頭,確保只對簽過名的cookie進行解析 if (str.substr(0, 2) !== 's:') {  return str; } // 校驗簽名的值是否合法,如合法,返回true,否則,返回false var val = unsign(str.slice(2), secret);  if (val !== false) {  return val; } return false;}

判斷、提取cookie原始值比較簡單。只是是 unsign 方法名比較有迷惑性。

一般只會對簽名進行合法校驗,并沒有所謂的反簽名。

unsign 方法的代碼如下:

  1. 首先,從傳入的cookie值中,分別提取出原始值A1、簽名值B1。
  2. 其次,用同樣的秘鑰對A1進行簽名,得到A2。
  3. 最后,根據A2、B1是否相等,判斷簽名是否合法。

exports.unsign = function(val, secret){

 var str = val.slice(0, val.lastIndexOf('.'))  , mac = exports.sign(str, secret);  return sha1(mac) == sha1(val) ? str : false;};

cookie簽名的作用

主要是出于安全考慮, 防止cookie被篡改 ,增強安全性。

舉個小例子來看下cookie簽名是如何實現防篡改的。

基于前面的例子展開。假設網站通過 nick 這個cookie來區分當前登錄的用戶是誰。在前面例子中,登錄用戶的cookie中,nick對應的值如下:(decode后的)

s:chyingp.uVofnk6k+9mHQpdPlQeOfjM8B5oa6mppny9d+mG9rD0

此時,有人試圖修改這個cookie值,來達到偽造身份的目的。比如修改成 xiaoming :

s:xiaoming.uVofnk6k+9mHQpdPlQeOfjM8B5oa6mppny9d+mG9rD0

當網站收到請求,對簽名cookie進行解析,發現簽名驗證不通過。由此可判斷,cookie是偽造的。

hmac("xiaoming", "secret") !== "uVofnk6k+9mHQpdPlQeOfjM8B5oa6mppny9d+mG9rD0"

簽名就一定能夠確保安全嗎

當然不是。

上個小節的例子,僅通過 nick 這個cookie的值來判斷登錄的是哪個用戶,這是一個非常糟糕的設計。雖然在秘鑰未知的情況下,很難偽造簽名cookie。但用戶名相同的情況下,簽名也是相同的。這種情況下,其實是很容易偽造的。

另外,開源組件的算法是公開的,因此秘鑰的安全性就成了關鍵,要確保秘鑰不泄露。

還有很多,這里不展開。

小結

本文主要對 Express + cookie-parser 的簽名和解析機制進行相對深入的介紹。

不少類似的總結文章中,把cookie的簽名說成了加密,這是一個常見的錯誤,讀者朋友需要注意一下。

簽名部分的介紹,稍微涉及一些簡單的安全知識,對這塊不熟悉的同學可以留言交流。為講解方便,部分段落、用詞可能不夠嚴謹。如有錯漏,敬請指出。

相關鏈接

https://github.com/expressjs/cookie-parser

https://github.com/chyingp/nodejs-learning-guide

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
九九精品视频在线| 国产女同一区二区| 91在线无精精品一区二区| 欧美影院久久久| 国产v综合ⅴ日韩v欧美大片| 日韩av电影院| 日本精品久久久久影院| 欧美在线视频一区二区| 97超级碰在线看视频免费在线看| 欧美激情视频给我| 日韩美女av在线免费观看| 中文字幕亚洲欧美日韩2019| 亚洲片国产一区一级在线观看| 欧美裸体xxxx极品少妇| 国产精品久久久久高潮| 国产脚交av在线一区二区| 亚洲欧美日韩一区二区在线| 国产欧美精品一区二区| 欧美日韩一区二区免费在线观看| 日韩成人在线视频观看| 色偷偷噜噜噜亚洲男人的天堂| 日本伊人精品一区二区三区介绍| 日韩三级影视基地| 亚洲国产一区二区三区在线观看| 欧美成人在线网站| 久久精品国产91精品亚洲| 国产在线视频2019最新视频| 91久热免费在线视频| 欧美国产精品va在线观看| 亚洲小视频在线观看| 国产精品久久久久国产a级| 亚洲国产精品嫩草影院久久| 久久亚洲国产精品成人av秋霞| 亚洲高清久久久久久| 伊人久久久久久久久久久久久| 在线日韩精品视频| 亚洲免费成人av电影| 国产综合视频在线观看| 久久av在线播放| 久久久久久久久久久久久久久久久久av| 欧美精品videofree1080p| 国产精品成人观看视频国产奇米| 日韩免费观看av| 国产精品久久久久久一区二区| 清纯唯美亚洲激情| 国产ts人妖一区二区三区| 亚洲香蕉成人av网站在线观看| 国产日韩欧美自拍| 久久久爽爽爽美女图片| 91中文精品字幕在线视频| 日韩精品免费在线观看| 亚洲精品98久久久久久中文字幕| 久久久久久久久91| 日韩精品免费看| 亚洲性猛交xxxxwww| 啪一啪鲁一鲁2019在线视频| 亚洲欧美一区二区精品久久久| 国产精品jizz在线观看麻豆| 日韩黄色在线免费观看| 成人中文字幕在线观看| 亚洲欧美一区二区三区情侣bbw| 岛国av一区二区在线在线观看| 色在人av网站天堂精品| 26uuu另类亚洲欧美日本一| 久久久精品一区二区| 欧美激情精品久久久久久免费印度| 97视频免费在线观看| 日韩av在线免费观看一区| 国产精品久久9| 韩国欧美亚洲国产| 欧美国产日韩中文字幕在线| 日韩欧美中文第一页| 国产欧美婷婷中文| 夜夜嗨av一区二区三区四区| 福利微拍一区二区| 成人精品久久一区二区三区| 欧美日韩国产成人| 日韩性xxxx爱| 亚洲bt天天射| 伊人亚洲福利一区二区三区| 日韩成人久久久| 中文字幕日韩欧美| 精品国产一区av| 91色精品视频在线| 久久亚洲精品一区二区| 日韩亚洲精品电影| 国产在线观看不卡| 国产午夜精品美女视频明星a级| 久久九九免费视频| 国产精品一区二区三区成人| 日韩欧美国产黄色| 久久九九免费视频| 国产精品狼人色视频一区| 亚洲风情亚aⅴ在线发布| 91欧美精品午夜性色福利在线| 午夜精品久久久久久久久久久久| 97人人做人人爱| 欧美精品手机在线| 精品一区二区三区电影| 国产亚洲精品久久久| 日韩欧美国产高清91| 亚洲女人被黑人巨大进入al| 欧美日韩电影在线观看| 久久九九精品99国产精品| 久久久久久久999精品视频| 欧美在线播放视频| 欧美激情videoshd| 亚洲国产精品久久久| 色悠悠国产精品| 成人xvideos免费视频| 欧美性猛交99久久久久99按摩| 91精品国产自产91精品| 综合国产在线视频| 超碰精品一区二区三区乱码| 日韩久久精品成人| 亚洲人成亚洲人成在线观看| 亚洲欧美一区二区三区四区| 日韩人体视频一二区| 91亚洲精品一区| 欧美色图在线视频| 日韩视频亚洲视频| 日韩精品一区二区三区第95| 国产精品视频yy9099| 亚洲视频999| 日韩亚洲成人av在线| 国产精品国产亚洲伊人久久| 欧洲亚洲免费在线| 国产偷国产偷亚洲清高网站| 久久99精品久久久久久青青91| 亚洲国产另类久久精品| 国产专区欧美专区| 欧美精品videosex牲欧美| 久久久久国色av免费观看性色| 国产精品福利片| 欧美成人精品一区二区| 日韩午夜在线视频| 久久99亚洲精品| 97在线视频一区| 欧美成人性生活| 国产精品免费一区| 国产精品美乳在线观看| 亚洲免费高清视频| 在线电影中文日韩| 亚洲精品日韩在线| 欧美另类极品videosbestfree| 欧美激情久久久久久| 久久精品人人爽| 欧美成人免费在线视频| 久久中文字幕在线| 欧美激情日韩图片| 亚洲人成在线免费观看| 欧美天天综合色影久久精品| 好吊成人免视频| 欧美麻豆久久久久久中文| 国产精品尤物福利片在线观看| 国产香蕉97碰碰久久人人| 欧美国产日本在线| 国产香蕉97碰碰久久人人| 久久久精品视频在线观看| 欧美体内谢she精2性欧美| 97在线视频免费播放| 亚洲男人的天堂网站| 精品视频一区在线视频| 欧美性生活大片免费观看网址|