• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    全面掌握Expresscookie-parser中間件

    來源:懂視網 責編:小采 時間:2020-11-27 20:04:07
    文檔

    全面掌握Expresscookie-parser中間件

    全面掌握Expresscookie-parser中間件:cookie-parser 是Express的中間件,用來實現cookie的解析,是官方腳手架內置的中間件之一。它的使用非常簡單,但在使用過程中偶爾也會遇到問題。一般都是因為對 Express + cookie-parser 的簽名、驗證機制不了解導致的。本文主要和大家介紹Express c
    推薦度:
    導讀全面掌握Expresscookie-parser中間件:cookie-parser 是Express的中間件,用來實現cookie的解析,是官方腳手架內置的中間件之一。它的使用非常簡單,但在使用過程中偶爾也會遇到問題。一般都是因為對 Express + cookie-parser 的簽名、驗證機制不了解導致的。本文主要和大家介紹Express c

    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的簽名說成了加密,這是一個常見的錯誤,讀者朋友需要注意一下。

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

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    全面掌握Expresscookie-parser中間件

    全面掌握Expresscookie-parser中間件:cookie-parser 是Express的中間件,用來實現cookie的解析,是官方腳手架內置的中間件之一。它的使用非常簡單,但在使用過程中偶爾也會遇到問題。一般都是因為對 Express + cookie-parser 的簽名、驗證機制不了解導致的。本文主要和大家介紹Express c
    推薦度:
    標簽: express exp 中間件
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 四虎国产精品免费久久久| 国产精品麻豆入口| 亚洲综合精品香蕉久久网97| 亚洲精品网站在线观看不卡无广告| 久久青草国产精品一区| 少妇人妻无码精品视频| 久久亚洲精品无码观看不卡| 亚洲国产成人精品不卡青青草原| 精品久久久久久国产潘金莲| 亚洲精品无码99在线观看| 久久免费99精品国产自在现线| 亚洲国产成人精品不卡青青草原| 2022国产精品福利在线观看| 久久夜色精品国产噜噜亚洲AV | 久久九九亚洲精品| 国产精品天干天干综合网| 亚洲精品成人无码中文毛片不卡| 久久无码人妻精品一区二区三区| 国产精品99久久久久久宅男 | 亚洲精品制服丝袜四区| 久久久精品波多野结衣| 国产精品龙口护士门在线观看| 久久99精品综合国产首页| heyzo高无码国产精品| 久久久久无码精品国产不卡| 中文字幕日韩精品无码内射| 日韩精品毛片| 四虎永久在线精品免费一区二区| 久久91精品综合国产首页| 国产亚洲精品国看不卡| 精品露脸国产偷人在视频 | 国产精品国产三级专区第1集| 国产精品三级在线观看无码| 精品乱码一区二区三区四区| 国精品无码一区二区三区左线| 精品一区二区三区在线成人| 久久国产精品99精品国产| 国产精品成熟老女人视频| 国产精品免费观看调教网| 国精品午夜福利视频不卡| 国产2021精品视频免费播放 |