欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

koa2服務端使用jwt進行鑒權及路由權限分發(fā)的流程分析

 更新時間:2019年07月22日 10:49:55   作者:陌上兮月  
這篇文章主要介紹了koa2服務端使用jwt進行鑒權及路由權限分發(fā) ,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下

大體思路

  后端書寫REST api時,有一些api是非常敏感的,比如獲取用戶個人信息,查看所有用戶列表,修改密碼等。如果不對這些api進行保護,那么別人就可以很容易地獲取并調用這些 api 進行操作。

  所以對于一些api,在調用之前,我們在服務端必須先對操作者進行“身份認證”,這就是所謂的鑒權。

  Json Web Token 簡稱為 JWT,它定義了一種通信雙方之間以 JSON 對象的形式安全傳遞信息的方法。JWT 可以使用 HMAC 算法或者是 RSA 的公鑰密鑰對進行簽名,復雜度較高,換來的是更可靠的安全系數。

  整個認證的流程大體如下:

  首先用戶登錄的接口是不用token認證的,因為這個接口本身就是token的產生來源。前端輸入用戶名和密碼后請求服務器登錄接口,服務器驗證用戶名密碼正確后,生成token并返回給前端,前端存儲token,并在后面的請求中把token帶在請求頭中傳給服務器,服務器驗證token有效,才可以進行下一步操作。

服務器生成token

  由于我們的服務端使用 Koa2 框架進行開發(fā),除了要使用到 jsonwebtoken 庫之外,還要使用一個 koa-jwt 中間件,該中間件針對 Koa 對 jsonwebtoken 進行了封裝,使用起來更加方便。

 const router = require('koa-router')();
const jwt = require('jsonwebtoken');
const userModel = require('../models/userModel.js');
router.post('/login', async (ctx) => {
 const data = ctx.request.body;const result = await userModel.findOne({
  name: data.name,
  password: data.password
 })
 if(result !== null){
  const token = jwt.sign({
   name: result.name,
   _id: result._id
  }, 'zhangnan', { expiresIn: '2h' });
  return ctx.body = {
   code: 200,
   token: token,
   msg: '登錄成功'
  }
 }else{
  return ctx.body = {
   code: 400,
   token: null,
   msg: '用戶名或密碼錯誤'
  }
 }
});
module.exports = router;

 ?。ㄗ⒁猓哼@里暫時不討論加鹽加密校驗,實際項目中密碼不可能這樣明文驗證,這里只是為了著重討論token鑒權。在驗證了用戶名密碼正確之后,就可以調用 jsonwebtoken 的 sign() 方法來生成token,接收三個參數,第一個是載荷,用于編碼后存儲在 token 中的數據,也是驗證 token 后可以拿到的數據;第二個是密鑰,自己定義的,隨便寫個什么單詞都可以,但是驗證的時候一定要相同的密鑰才能解碼;第三個是options,可以設置 token 的過期時間。)

前端獲取token

  接下來就是前端獲取 token,這里是在 vue.js 中使用 axios 進行請求,請求成功之后拿到 token 保存到 localStorage 中。

submit(){
 axios.post('/login', {
  name: this.username,
  password: this.password
 }).then(res => {
  if(res.code === 200){
   localStorage.setItem('token', res.data.token);
  }else{
   this.$message('登錄失敗')
  }
 })
}

  然后前端在請求后端api時,就把 token 帶在請求頭中傳給服務器進行驗證。每次請求都要獲取 localStorage 中的 token,這樣很麻煩,這里使用了 axios 的請求攔截器,進行全局設置,對每次請求都進行了取 token 放到 headers 中的操作。

axios.interceptors.request.use(config => {
 const token = localStorage.getItem('token');
 config.headers.common['Authorization'] = 'Bearer ' + token;
 return config;
})

(這段代碼,如果是vue項目,可以直接放在main.js中設置,表示每次請求前都會往請求頭的authorization里塞一個token,至于那個Bearer 是koa-jwt的一個標識單詞,方便解析)

服務器驗證token

  接下來服務器收到前端發(fā)過來的token后,就可以進行驗證。

const koa = require('koa');
const koajwt = require('koa-jwt');
const app = new koa();

app.use(koajwt({
 secret: 'zhangnan'
}).unless({
  path: [/\/register/, /\/login/]
}));

(在這里沒有定義錯誤處理函數,由于出現(xiàn)錯誤后會返回401,所以我直接就讓前端來處理這種異常情況,給出一個錯誤的交互提示即可)

分析koa-jwt源碼

  我們在node_mudules里面找到koa-jwt/lib/resolvers文件夾下的auth-header.js文件,看下koa-jwt做了些什么

 ?。梢钥吹剿窍扰袛嗾埱箢^中是否帶了 authorization,如果有,則通過正則將 token 從 authorization 中分離出來,這里我們也看到了Bearer這個單詞。如果沒有 authorization,則代表了客戶端沒有傳 token 到服務器,這時候就拋出 401 錯誤狀態(tài)。)

  再看看上一級的vertify.js。

 ?。梢钥吹皆?verify.js 中,它就是調用 jsonwebtoken 原生提供的 verify() 方法進行驗證返回結果。jsonwebtoken 的 sign() 方法用于生成 token ,而 verify() 方法當然則是用來解析 token。屬于jwt配對生產的兩個方法,所以koa-jwt這個中間件也沒做什么事,無非就是用正則解析請求頭,調用jwt的vertify方法驗證token,在koa-jwt文件夾的index.js中,koa-jwt還調用koa-unless進行路由權限分發(fā))

  以上就是json web token的大體流程。

總結

以上所述是小編給大家介紹的koa2服務端使用jwt進行鑒權及路由權限分發(fā)的流程分析,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

相關文章

  • Js獲取圖片原始寬高的實現(xiàn)代碼

    Js獲取圖片原始寬高的實現(xiàn)代碼

    下面小編就為大家?guī)硪黄狫s獲取圖片原始寬高的實現(xiàn)代碼。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考,一起跟隨小編過來看看吧
    2016-05-05
  • uniapp?App端使用高德地圖超詳細步驟

    uniapp?App端使用高德地圖超詳細步驟

    地圖現(xiàn)在已經滲入到生活的方方面面,給生活帶了極大的編譯,那么我們如何才能在項目中引入地圖呢?這篇文章主要給大家介紹了關于uniapp?App端使用高德地圖超詳細步驟的相關資料,需要的朋友可以參考下
    2023-11-11
  • JS動態(tài)添加選項案例分析

    JS動態(tài)添加選項案例分析

    這篇文章主要介紹了JS動態(tài)添加選項的方法,結合實例形式分析了javascript針對頁面元素動態(tài)操作的相關技巧,需要的朋友可以參考下
    2016-10-10
  • 第三章之Bootstrap 表格與按鈕功能

    第三章之Bootstrap 表格與按鈕功能

    Bootstrap 是基于 HTML、CSS、JAVASCRIPT 的,它簡潔靈活,使得 Web 開發(fā)更加快捷。本文給大家介紹Bootstrap 表格與按鈕功能,感興趣的朋友參考下吧
    2016-04-04
  • JS中‘hello’與new String(‘hello’)引出的問題詳解

    JS中‘hello’與new String(‘hello’)引出的問題詳解

    這篇文章主要給大家介紹了關于JS中'hello'與new String('hello')引出的問題的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧
    2018-08-08
  • js確認刪除對話框適用于a標簽及submit

    js確認刪除對話框適用于a標簽及submit

    這篇文章主要介紹的是一個js確認刪除對話框適用于a標簽及submit,非常好用,需要的朋友不要錯過
    2014-07-07
  • 如何基于filter實現(xiàn)網站整體變灰功能

    如何基于filter實現(xiàn)網站整體變灰功能

    這篇文章主要介紹了如何基于filter實現(xiàn)網站整體變灰功能,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-04-04
  • 在TypeScript項目中進行BDD測試

    在TypeScript項目中進行BDD測試

    這篇文章主要介紹了在TypeScript項目中進行BDD測試,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪
    2022-04-04
  • 詳解小程序緩存插件(mrc)

    詳解小程序緩存插件(mrc)

    這篇文章主要介紹了詳解小程序緩存插件(mrc),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08
  • 通過設置CSS中的position屬性來固定層的位置

    通過設置CSS中的position屬性來固定層的位置

    position 屬性規(guī)定元素的定位類型,這個屬性定義建立元素布局所用的定位機制,本文給大家介紹通過設置CSS中的position屬性來固定層的位置,感興趣的朋友一起學習吧
    2015-12-12

最新評論