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

首頁 > 編程 > JavaScript > 正文

Nodejs中的JWT和Session的使用

2019-11-19 13:12:05
字體:
來源:轉載
供稿:網友

最近的項目需要在node服務端做一個用戶登錄的校驗以及權限攔截,專業一點叫用戶認證與授權,經過一番收集資料,目前常用的有兩種――JWT和Session

使用JWT

JWT是JsonWebTokens的簡寫形式,具體是啥我就不詳細寫了,可以查看資料。
這里引入兩個插件,express-jwt和JsonWebTokens,-

  1. JsonWebTokens:用作生成token
  2. express-jwt:用作驗證指定http請求的JsonWebTokens的有效性,如果有效就將JsonWebTokens的值設置到req.user里面,然后路由到相應的router

express-jwt內部引用了jsonwebtoken,對其封裝使用。使用JWT形式進行認證與授權的思路如下。

jwt認證流程

在服務端中使用方式如下:

//安裝npm i jsonwebtoken --savenpm i express-jwt --save//引入const jwt= require('jsonwebtoken');const expressJwt = require('express-jwt');//定義簽名const secret = 'salt';//生成tokenconst token = jwt.sign({  name: 123}, secret, {  expiresIn: 60 //秒到期時間});//生成的token//eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJuYW1lIjoxMjMsImlhdCI6MTQ5MTQ3NTQyNCwiZXhwIjoxNDkxNDc1NDg0fQ.hYNC4qFAyhZClmPaLixfN137d41R2CFk1xPlfLK10JU//使用中間件驗證token合法性app.use(expressJwt ({  secret: secret }).unless({  path: ['/login', '/getUserInfo'] //除了這些地址,其他的URL都需要驗證}));//攔截器app.use(function (err, req, res, next) {  //當token驗證失敗時會拋出如下錯誤  if (err.name === 'UnauthorizedError') {      //這個需要根據自己的業務邏輯來處理( 具體的err值 請看下面)    res.status(401).send('invalid token...');  }});//定義一個接口,返回token給客戶端app.get('/getUserInfo', function(req, res) {  res.json({    token: token  })})

客戶端中使用token的正確形式應該是把token放在authorization 這個header里, 對應的值以Bearer開頭然后空一格

authorization:Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJuYW1lIjoiQmluTWFpbmciLCJkYXRhIjoiPT09PT09PT09PT09PSIsImlhdCI6MTUwMTgxNDE4OCwiZXhwIjoxNTAxODE0MjQ4fQ.GoxGlc6E02W5VvqDNawaOrj3MPO-4UYeFdngKR4bVTE//采用axios可以這么寫const instance = axios.create();const yourToken = 'sfsgagfdgd';//設置請求攔截器instance.interceptors.request.use(function(config) {  config.headers.authorization = `Bearer ${yourToken}`   return config;})

使用Session

傳統的認證和用戶識別分別采用如下形式

  • 服務端:創建一個session對象保存用戶登錄信息和狀態,該對象有唯一ID,并返回一個cookie給客戶端
  • 客戶端:請求api時發送http頭部自動帶上cookie

這里使用cookie的方式需要引入兩個插件:

  • express-session:node端的session中間件,主要用作配置session的屬性并生成
  • cookie-parser:node端解析cookie對象

使用思路和JWT差不多,這里主要的區別在于客戶端請求資源時不用手動在http請求的header添加標識,瀏覽器會自動加上cookie,具體使用方式如下

var express = require('express');var cookieParser = require('cookie-parser');var session = require('express-session'); app.use(cookieParser('sessiontest'));app.use(session({  secret: 'sessiontest',//與cookieParser中的一致  resave: true,  //(是否允許)當客戶端并行發送多個請求時,其中一個請求在另一個請求結束時對session進行修改覆蓋并保存。  rolling: true,  //強制在每個響應中重設cookie的過期時間,并重新開始計時  saveUninitialized:true,  //初始化session時是否保存到存儲。默認為true, 但是(后續版本)有可能默認失效,所以最好手動添加。  cookie: {    maxAge: 60 * 1000 //過期時間,單位毫秒  }}));/** * 資源請求攔截器 * 用戶端若登錄狀態過期或未登錄則自動拋出錯誤 */app.use(function(req, res, next) {  let url = req.originalUrl;  req.session.touch(); //刷新session過期時間  if (url !== '/login' && !req.session.user) {    res.status(401).send('登錄狀態已過期');    return  }  next();})

對比

作為一個實踐派人士,我把兩種都試了一遍,同時結合網上的博客歸納了如下對比

  1. JWT無狀態,可擴展和解耦。使用JWT不需要后端進行記錄,每個token都是獨立的。而session的誕生就是為了解決http無狀態的問題,這也就說明服務端是有存儲每個用戶對應的session對象的,擴展性會更繁瑣些
  2. 跨域和CORS。每次發送請求到后端都需要檢查JWT,只要驗證通過就能處理請求。而Cookie只能在單域和子域中發揮作用
  3. JWT生成消耗一定的內存,而且體積較大,最小的它都比cookie要大,如果JWT里包含了許多聲明,那問題就比較嚴重了,由于每次向服務器發起請求都要攜帶token,太大了會造成請求緩慢
  4. session比JWT好的地方在于在請求時瀏覽器會自動帶http頭部帶上cookie,并且在用戶持續使用時會不斷地刷新session的過期時間,當瀏覽器關閉時自動清除session。相比之下JWT本身沒法做到隨著用戶的使用而更新或手動清除,只能等自動過期

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品wwwwww| 日韩精品极品毛片系列视频| 欧美日韩激情美女| 在线观看久久久久久| 国产精品久久久久久久9999| 亚洲成人在线网| 另类专区欧美制服同性| 精品亚洲国产视频| 精品国偷自产在线视频| 午夜精品蜜臀一区二区三区免费| 成人国产在线视频| 日韩精品极品视频免费观看| 日韩激情片免费| 中文字幕视频在线免费欧美日韩综合在线看| 亚洲精品白浆高清久久久久久| 欧美电影在线免费观看网站| 亚洲国产毛片完整版| 日韩免费观看高清| 91av中文字幕| 亚洲国产精品va在线| 日韩av网站大全| 91成人在线视频| 欧美大片在线看| 日韩成人在线视频观看| 亚洲精品日韩av| 久久久久亚洲精品成人网小说| 欧美一级在线播放| 亚洲国产欧美自拍| 日韩中文在线不卡| 91综合免费在线| 精品亚洲一区二区| 国产精品男女猛烈高潮激情| 成人亚洲欧美一区二区三区| 国产精品久久久av| 成人a免费视频| 精品久久久一区| 日韩在线精品一区| 91精品久久久久久久久久久久久久| 色综合视频一区中文字幕| 亚洲国产高潮在线观看| 丝袜美腿亚洲一区二区| 欧美激情精品久久久久久久变态| 国产精品午夜视频| 国产精品色悠悠| 日韩精品亚洲精品| 另类图片亚洲另类| 精品福利在线视频| 正在播放欧美视频| 欧美精品videossex性护士| 亚洲电影免费观看高清完整版在线观看| 日本道色综合久久影院| 日韩中文字幕免费视频| 亚洲精品久久久久中文字幕欢迎你| 一本一本久久a久久精品综合小说| 欧洲亚洲妇女av| 久久97久久97精品免视看| 色老头一区二区三区在线观看| 亚洲精品日韩丝袜精品| 国产在线一区二区三区| 97精品国产97久久久久久免费| 久久香蕉国产线看观看网| 亚洲精品一区二区在线| 精品国产乱码久久久久久天美| 色偷偷9999www| 亚洲精品成人网| 欧美麻豆久久久久久中文| 国产精品久久91| 国产精品久久久久久一区二区| 亚洲国产成人久久综合| 不用播放器成人网| 91影院在线免费观看视频| 国产欧美亚洲视频| 激情懂色av一区av二区av| 精品国产乱码久久久久久虫虫漫画| 91久久久亚洲精品| 色一区av在线| 日本午夜人人精品| 日韩av在线免费看| 亚洲国产黄色片| 91精品视频免费观看| 精品国产电影一区| 亚洲成**性毛茸茸| 中文字幕日韩视频| 国产一区深夜福利| 国产精品久久久久久网站| 日韩免费观看高清| 欧美性受xxxx黑人猛交| 久久久伊人日本| 国产丝袜一区二区三区免费视频| 欧美电影在线免费观看网站| 日韩在线免费视频| 在线成人激情黄色| 国产亚洲欧洲黄色| 久久艹在线视频| 国产精品美女主播在线观看纯欲| 亚洲最大激情中文字幕| 亚洲精品一区二区网址| 亚洲人a成www在线影院| 6080yy精品一区二区三区| 中文字幕在线看视频国产欧美| 日韩最新中文字幕电影免费看| 九九精品视频在线观看| 亚洲欧美国产高清va在线播| 91在线|亚洲| 亚洲自拍高清视频网站| 欧美日韩色婷婷| 久久国产精品久久久| 国产精品视频精品视频| 海角国产乱辈乱精品视频| 欧洲成人免费视频| 精品国产乱码久久久久酒店| 韩国福利视频一区| 国产精品狼人色视频一区| 青草青草久热精品视频在线观看| 精品亚洲一区二区三区在线播放| 成人性生交大片免费看小说| 日韩欧美在线网址| 国产精品久久久久久久久久| 久久亚洲成人精品| 日韩欧美国产中文字幕| 亚洲成人性视频| 欧美一区二区三区免费观看| 亚洲一区二区免费| 欧美日韩中文字幕日韩欧美| 亚洲欧美成人精品| 国产视频欧美视频| 日本久久久久久久| 国产精品午夜视频| 久久躁狠狠躁夜夜爽| 97热在线精品视频在线观看| 久久精品视频va| 精品视频www| 欧美性极品xxxx娇小| 亚洲一区二区久久久| 国产成人涩涩涩视频在线观看| 国产成人精品国内自产拍免费看| 成人精品视频99在线观看免费| 中文字幕亚洲在线| 97超级碰碰碰久久久| 日韩激情av在线免费观看| 日韩电影在线观看永久视频免费网站| 尤物99国产成人精品视频| 国产一区二区激情| 伊人精品在线观看| 久久五月情影视| 91免费国产视频| 欧美成人午夜影院| 亚洲高清av在线| 亚洲欧美国产精品久久久久久久| 色播久久人人爽人人爽人人片视av| 日韩精品免费综合视频在线播放| 国产成人精品av在线| 欧美一级免费视频| 国产精品视频公开费视频| 日韩中文字幕在线视频| 国产精品jvid在线观看蜜臀| 91成人国产在线观看| 在线播放精品一区二区三区| 久久精品亚洲一区| 欧美国产乱视频| 精品福利一区二区| 91成人福利在线| 中文字幕亚洲图片| 日韩免费观看网站|