久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > web前端培訓(xùn)之雙token的神奇功效-登陸驗證

web前端培訓(xùn)之雙token的神奇功效-登陸驗證

來源:千鋒教育
發(fā)布人:小千
時間: 2021-08-09 09:06:00 1628471160

      細(xì)心的你可能會發(fā)現(xiàn),我們在使用app的時候只需要登陸一次賬號之后下一次打開就不需要再次登陸,但經(jīng)過一段時間不登錄之后又會要求我們重新登陸,你知道這是如何實現(xiàn)的嗎?

      雙token驗證

<a href=web前端培訓(xùn)雙token1" />

      具體說明如下:

      1.根據(jù)需要下載軟件,完成注冊賬戶

      2.登錄賬戶,后端返回 兩個token信息,分別為 access_token 以及 refresh_token,access_token稱之為短token,refresh_token稱之為長token

      3.短token也就是access_token未過期,所有的請求一切都正常,用戶需要什么數(shù)據(jù)就返回什么數(shù)據(jù)

      4.access_token 過期,服務(wù)端返回一個狀態(tài)碼給客戶端,客戶端接收到該狀態(tài)碼之后,使用refresh_token重新獲取一次新的 access_token 和 refresh_token,相當(dāng)于重置token

      5.如果在refresh_token有效期中沒有使用過該軟件,意味著refresh_token過期,使用它獲取新的 access_token 和 refresh_token 時會返回新的一個狀態(tài)碼,提示用戶必須登錄

      有的人可能會有如下疑問:

      為什么在使用 refresh_token 時要返回新的 access_token 和 refresh_token,而不是延長 原來的 refresh_token 有效期?

      為了安全,如果一旦 refresh_token 被黑客等人員截獲到,他們就一直可以非法使用你的賬號

      即使一旦被截獲,只要用戶這邊刷新就會重新獲取到新的 refresh_token,那么以前的 被截獲的 refresh_token 就會失效

      token的時間設(shè)置

      token的時間設(shè)置需要看需求進(jìn)行劃分區(qū)別設(shè)置:

      PC網(wǎng)絡(luò)應(yīng)用:對于網(wǎng)絡(luò)應(yīng)用程序而言,由于token可以直接直觀地獲取到,因此不管是accessToken還是refreshToken為了安全起見,其過期時間都不應(yīng)該設(shè)置得很長,且需要不停地更換token,因此PC網(wǎng)絡(luò)應(yīng)用的accessToken一般設(shè)置為2h過期,而refreshToken設(shè)置為1天到2天比較好,不足1天也是可以的,如果設(shè)置的時間比較短就在活躍期間時常刷新freshToken就好了,如果設(shè)置的時間比較長,就只需要設(shè)置一個閾值(比如7day的refreshToken設(shè)置一個6day閾值),在refreshToken小于等于這個閾值的時候就進(jìn)行刷新refreshToken就好了。

      手機(jī)應(yīng)用:對于手機(jī)APP應(yīng)用而言,登錄操作一般只做一次,因此token的過期時間必是無限,即不會過期,不過為了安全起見(比如防止你丟手機(jī)),token應(yīng)該以某種程度上對用戶可見(比如在安全中心里檢驗了身份之后可以讓你看到哪些設(shè)備有token,即哪些設(shè)備會被允許登錄)并可讓用戶對其進(jìn)行一定程度上的操作(比如你手機(jī)丟了,然后登錄安全中心移除那個手機(jī)的token,也就是移除那個手機(jī)的登陸權(quán)限,從而使那個手機(jī)的應(yīng)用上的你的帳號強(qiáng)制下線)

      無效的Token的處理

      對于頻繁更換的Token,如何處理舊的未過期的而又無效的Token,以下提供了幾個思路:

      1.簡單地從瀏覽器中移除token就好了

      顯然,這種方式對于服務(wù)器方面的安全而言并沒有什么卵用,但它能通過移除存在的token來阻止攻擊者(比如,攻擊者必須在用戶下線之前竊取到token)

      2.制作一張token黑/白名單

      在移除了瀏覽器存儲的token后如果還想要再嚴(yán)格點,就只能在服務(wù)器上制作一張已經(jīng)無效但是沒過期的token的黑/白名單了,在每次請求中都操作數(shù)據(jù)庫進(jìn)行token的匹配,并以某種方式進(jìn)行維護(hù)(不管是黑名單的定期刪除維護(hù)也好,白名單的無效時刪除也好),不過顯然這種方式還是違背了token無狀態(tài)的初衷,但是除此之外也沒別的辦法。

      存儲可以按照userId—token的方式存儲在數(shù)據(jù)庫中(當(dāng)然也可以按你喜歡添加其他字段標(biāo)明其他信息,比如說mac地址啦,是手機(jī)還是電腦啦,設(shè)備型號啦,巴拉巴拉巴拉····),白名單的話直接存儲有效的token,在需要token無效的邏輯中刪除指定token即可(比如刷新token的時候把舊的無效的但未過期的刪掉)。而如果是黑名單的話就需要你定期去刪除其中已經(jīng)過期的token了。而驗證的話除了要去數(shù)據(jù)庫名單里匹配之外還需要驗證token本身的有效性。

      3.只需要將token的過期時間設(shè)置的足夠短就行了

      如何刷新Token(引用自github)

token

      以上就是雙token登陸驗證的介紹了,同學(xué)們不妨親自去試試,最后如果你對web前端培訓(xùn)感興趣的話,不妨來千鋒WEB前端培訓(xùn)班參加我們的web前端培訓(xùn)課程的學(xué)習(xí),現(xiàn)在咨詢更有免費學(xué)習(xí)資料可以領(lǐng)取,還有海量免費學(xué)習(xí)資料,趕緊去了解一下吧。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
前端html5框架有哪些?

一、BootstrapBootstrap是目前較受歡迎的前端HTML5框架之一。它由Twitter開發(fā)并開源,提供了一套易于使用的CSS和JavaScript組件,可以用于創(chuàng)建...詳情>>

2023-10-14 00:57:59
哪些平臺支持Python編程?

一、AnacondaAnaconda是一個流行的Python發(fā)行版和包管理器,它提供了一個集成環(huán)境,方便進(jìn)行科學(xué)計算和數(shù)據(jù)分析。Anaconda附帶了許多常用的Pyth...詳情>>

2023-10-14 00:54:07
數(shù)據(jù)庫可重復(fù)讀這種隔離級別的意義是什么?

一、數(shù)據(jù)庫可重復(fù)讀這種隔離級別的意義數(shù)據(jù)庫可重復(fù)讀這種隔離級別的意義是,repeatable read隔離級別確保在同一個事務(wù)中讀取同一行多次,得到...詳情>>

2023-10-14 00:50:53
有什么工具能進(jìn)行服務(wù)器性能監(jiān)控?

一、NagiosNagios是一款廣泛使用的開源監(jiān)控工具,用于監(jiān)控服務(wù)器、網(wǎng)絡(luò)設(shè)備和應(yīng)用程序的狀態(tài)和性能。它支持對各種指標(biāo)的監(jiān)控,如CPU使用率、內(nèi)...詳情>>

2023-10-14 00:12:36
應(yīng)用服務(wù)器與Web服務(wù)器有什么區(qū)別?

一、功能定位不同應(yīng)用服務(wù)器是一種軟件平臺,用于提供各種應(yīng)用程序的運行環(huán)境。它負(fù)責(zé)管理和執(zhí)行應(yīng)用程序的邏輯,處理數(shù)據(jù)傳輸和事務(wù)管理等任務(wù)...詳情>>

2023-10-14 00:05:39