koa-jwt

  • http 是無狀態(tài)協(xié)議。
  • 訪問一個服務(wù)器,不可能攜帶cookie。 必須是服務(wù)器得到這次請求,在下行響應(yīng)報頭中,攜帶cookie信息,此后每一次瀏覽器往這個服務(wù)器發(fā)出的請求,都會攜帶這個cookie
  ctx.cookies.set(name, value, [options])
  • 通過options 設(shè)置cookie name 的value
    ctx.cookies.get('name')

Usage 用法

JWT 身份驗證中間件使用jwt令牌 來驗證使用者身份,如果令牌是有效的,則在ctx.state.user(默認) 將設(shè)置被解密JSON,用作稍后的中間件授權(quán)和訪問控制

Retrieving the token 檢索令牌

三種方法

  1. 令牌默認是http請求頭部中的Authorization提供的。
  2. 它還可以由在opts.cookie 中設(shè)置的cookie提供。
  3. 自定義令牌檢索 由opts.getToken 選項提供
    令牌的解析順序
    3->2->1
  • opts.getToken [function]
  • check the cookies [??if opts.cookie is set]
  • check the Authorization header for a bearer token

Passing the secret

Checking if the token is revoked 檢測令牌是否已撤銷

opts.isRevoked

處理 鑒權(quán)失敗情況

if you don't want to expose koa-jwt errors to users

  app.use( (ctx, next) => {
    return next().catch((err) => {
        if(err.status === 401) {
            ctx.body = 'Protected resource, use Authorization header to get access\n aaa'
        }
    })
  })
  • 如果您更喜歡使用另一個ctx密鑰來解碼數(shù)據(jù),只需傳入密鑰 key
    設(shè)置密鑰key (我的理解,重命名key值 ,看源碼后發(fā)現(xiàn)果然如此)
      jwt({
          secret: 'uid',
          key: 'jwtdata'
      })
      // 獲取
      ctx.state.jwtdata  
      // { uid: 111, exp: 1540368721,  iat: 1540368667}
  • 可以指定issuer
  jwt({
    secret:  ['shared-secret', 'new-shared-secret'],
    audience: 'http://myapi/protected',
    issuer:   'http://issuer'
  })
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 物欲縱橫,工作壓力巨大的城市白領(lǐng),處于生活的無奈,工作的挫敗同時每個人心中都有一個華麗的伊甸園,可現(xiàn)實卻沒有時間和...
    擎擎C閱讀 1,033評論 0 0
  • 昨天,我做了個電燈泡。 女生是我朋友,她約了我,順便帶著男朋友一起,請我吃飯。 吃完飯后,我就陪著這對情侶逛街。 ...
    幽谷暄和8368閱讀 796評論 1 3
  • 一片葉子,這是秋天最后的樹葉,從枝頭飄落了下來,落在地上,清脆的聲音,寫著大自然的音符,天空很高很藍,大地一片茫茫……
    白子燕閱讀 395評論 0 1
  • 今天一大早來到了中洲中央花園的銷售中心會議室開始了新一天的培訓。由于昨天我們組獲得了很多資料,所以今天很大程...
    張潤chery閱讀 286評論 2 7

友情鏈接更多精彩內(nèi)容