亚洲 国产精品 日韩-亚洲 激情-亚洲 欧美 91-亚洲 欧美 成人日韩-青青青草视频在线观看-青青青草影院

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 為什么淘寶京東使用不是每次都需要登錄?雙token

為什么淘寶京東使用不是每次都需要登錄?雙token

來源:千鋒教育
發布人:wjy
時間: 2022-06-06 12:01:00 1654488060

## 背景

 現如今,人人有手機,手機皆為蘋果安卓等智能手機;

 現如今,人人愛網購,網購皆為淘寶京東等電商平臺。

 喜歡網購的你是否發現,下載好淘寶京東,只要你時不時的用一下它,就不用登錄了。

 為什么呢?

 從技術的角度而言,當用戶在一定的時間內使用過該平臺就可以不用再次登錄,但一定要注意的是首次肯定得登錄,如果用戶操過一定的時間沒有使用,就必須得重新登錄,這種方式我們將它稱之為雙token。

為什么淘寶京東使用不是每次都需要登錄

## 流程示意圖

![img](https://pic2.zhimg.com/80/v2-e568451b35740a726665d77c97793681_720w.jpg)

具體說明如下:

- 1.根據需要下載軟件,完成注冊賬戶
- 2.登錄賬戶,后端返回 兩個token信息,分別為 access_token 以及 refresh_token,access_token稱之為短token,refresh_token稱之為長token
- 3.短token也就是access_token未過期,所有的請求一切都正常,用戶需要什么數據就返回什么數據
- 4.access_token 過期,服務端返回一個狀態碼給客戶端,客戶端接收到該狀態碼之后,使用refresh_token重新獲取一次新的 access_token 和 refresh_token,相當于重置token
- 5.如果在refresh_token有效期中沒有使用過該軟件,意味著refresh_token過期,使用它獲取新的 access_token 和 refresh_token 時會返回新的一個狀態碼,提示用戶必須登錄

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

- 為什么在使用 refresh_token 時要返回新的 access_token 和 refresh_token,而不是延長 原來的 refresh_token 有效期?
- 為了安全,如果一旦 refresh_token 被黑客等人員截獲到,他們就一直可以非法使用你的賬號
- 即使一旦被截獲,只要用戶這邊刷新就會重新獲取到新的 refresh_token,那么以前的 被截獲的 refresh_token 就會失效

## token的時間設置

token的時間設置需要看需求進行劃分區別設置:

### PC網絡應用

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

### 手機應用

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

## 無效的Token的處理

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

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

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

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

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

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

而驗證的話除了要去數據庫名單里匹配之外還需要驗證token本身的有效性。

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

## 如何刷新Token(引用自github)

```text
static refreshToken = (token): string => {
    let optionKeys = ['iat', 'exp', 'iss', 'sub'];
    let newToken;
    let obj = {};

    let now = Math.floor(Date.now()/1000);
    let timeToExpire = (token['exp'] - now);

    if (timeToExpire < (60 * 60)) { //1h
        for (let key in token) {
            if (optionKeys.indexOf(key) === -1) {
                obj[key] = token[key];
            }
        }

        let options = {
            expiresIn: '7 days',
            issuer: 'moi',
            subject: token.sub,
            algorithm: 'HS256'
        };

        newToken = JWT.sign(obj, Config.get('/jwtSecret'), options);
    }
    else {
        newToken = '';  //no need to refresh, do what you want here.
    }

    return newToken;
}
```

## 刷新refreshToken的另一種思路(官網)

```text
/**
 * Example to refresh tokens using https://github.com/auth0/node-jsonwebtoken
 * It was requested to be introduced at as part of the jsonwebtoken library,
 * since we feel it does not add too much value but it will add code to mantain
 * we won't include it.
 *
 * I create this gist just to help those who want to auto-refresh JWTs.
 */

const jwt = require('jsonwebtoken');

function TokenGenerator (secretOrPrivateKey, secretOrPublicKey, options) {
  this.secretOrPrivateKey = secretOrPrivateKey;
  this.secretOrPublicKey = secretOrPublicKey;
  this.options = options; //algorithm + keyid + noTimestamp + expiresIn + notBefore
}

TokenGenerator.prototype.sign = function(payload, signOptions) {
  const jwtSignOptions = Object.assign({}, signOptions, this.options);
  return jwt.sign(payload, this.secretOrPrivateKey, jwtSignOptions);
}

// refreshOptions.verify = options you would use with verify function
// refreshOptions.jwtid = contains the id for the new token
TokenGenerator.prototype.refresh = function(token, refreshOptions) {
  const payload = jwt.verify(token, this.secretOrPublicKey, refreshOptions.verify);
  delete payload.iat;
  delete payload.exp;
  delete payload.nbf;
  delete payload.jti; //We are generating a new token, if you are using jwtid during signing, pass it in refreshOptions
  const jwtSignOptions = Object.assign({ }, this.options, { jwtid: refreshOptions.jwtid });
  // The first signing converted all needed options into claims, they are already in the payload
  return jwt.sign(payload, this.secretOrPrivateKey, jwtSignOptions);
}

module.exports = TokenGenerator;
```

測試模塊:

```text
/**
 * Just few lines to test the behavior.
 */

const TokenGenerator = require('./token-generator');
const jwt = require('jsonwebtoken');

const tokenGenerator = new TokenGenerator('a', 'a', { algorithm: 'HS256', keyid: '1', noTimestamp: false, expiresIn: '2m', notBefore: '2s' })
token = tokenGenerator.sign({ myclaim: 'something' }, { audience: 'myaud', issuer: 'myissuer', jwtid: '1', subject: 'user' })
setTimeout(function () {
  token2 = tokenGenerator.refresh(token, { verify: { audience: 'myaud', issuer: 'myissuer' }, jwtid: '2' })
  console.log(jwt.decode(token, { complete: true }))
  console.log(jwt.decode(token2, { complete: true }))
}, 3000)
```

更多關于web培訓的問題,歡迎咨詢千鋒教育在線名師。千鋒教育擁有多年IT培訓服務經驗,采用全程面授高品質、高體驗培養模式,擁有國內一體化教學管理及學員服務,助力更多學員實現高薪夢想。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
中国帅气体育生GARY网站| 亚洲综合精品伊人久久| 亚洲色18禁成人网站WWW| 最新国产乱人伦偷精品免费网站| YOUJIZZ丰满熟妇| 多P混交群体交乱的安全保障| 国产乱XXXXX97国语对白| 久久精品亚洲精品无码金尊| 欧美精产国品一二三类产品特点| 少妇被粗大的猛烈的进出69影院| 亚洲AV无码一区二区三区在线| 在线观看草莓视频MV的免费网站| 成年女人喷潮毛片免费播放| 国产在线精品一区二区高清不卡 | 久久精品噜噜噜成人AV| 欧美人与牲动交a欧美精品| 我和岳乱妇三级高清电影| 亚洲人成色777777网站| JJZZJJZZ高潮喷水妇女| 国产日韩一区在线精品| 免费无码AV片在线观看网站| 私人微信放款24小时在线| 亚洲色欲色欱WWW在线| 草莓视频IOS下载| 娇妻宾馆被三根粗大的夹击| 欧美怡春院一区二区三区| 午夜无遮挡男女啪啪免费软件| 在厨房拨开内裤进入毛片| 东京热人妻系列无码专区| 久久99精品久久久久久青青 | 亚洲AV成人男人的天堂手机| 坐在根茎写作业好吗| 国产AV旡码专区亚洲AV苍井空| 久久久久久毛片精品免费不卡 | 催眠性指导OVA1一6集| 精品国产乱码一区二区三区APP| 青草久久久国产线免观蜜芽| 亚洲AV综合色区无码三区30p| ASS年轻少妇PIC精品| 国精产品一二三四区产品| 欧美熟妇黑人ⅩXXXXX| 亚洲AV无码专区里番在线观看| AV无码一区二区大桥久未| 好满射太多了装不下了APP| 人妻夜夜爽天天爽三区| 亚洲人成网77777亚洲色| 村长用力挺进她的花苞啥电视| 久久久久久精品免费免费999 | 欧美日韩中文字幕视频不卡一二区 | 国产av一区二区三区| 娇妻被朋友玩得呻吟在线电影 | 爱情岛亚洲AV永久入口首页| 精品国产福利在线观看| 色AV综合AV综合无码网站| 夜夜躁狠狠躁日日躁2022| 国产SUV精品一区二区四| 妺妺窝人体色WWW看美女| 亚洲AⅤ精品无码一区二区PRO | 极品婬荡少妇XXXX欧美图片| 日韩人妻无码精品无码中文字幕| 尤物在线视频.YW163.成年| 国产日韩精品欧美一区喷水| 人人爽人人澡人人高潮| 又色又爽又黄18禁美女裸身无遮| 国产区图片区小说区亚洲区 | 国产成人无码区免费内射一片色欲| 免费看国产成年无码AV片| 亚洲成人Av在线| 国产成年女人毛片80S网站| 欧式春画图片大全欣赏简单| 一本久久伊人热热精品中文字幕| 国产男男猛烈无遮挡A片小说| 日本丰满人妻熟妇BBBBB③B| 中文毛片无遮挡高潮免费| 极品AV麻豆国产在线观看| 玩弄JaPan白嫩少妇HD小说| YELLOW高清免费观看日本| 久久天天躁夜夜躁狠狠2018| 亚洲AV永久无码精品无码网站| 福利 无码 三级 视频| 欧美最猛黑人XXXX黑人猛交9| 在线观看4480私人影视| 精品无码无人网站免费视频| 午夜香吻视频在线看免费| 第一次处破女01免费观看| 欧美人妻少妇精品久久黑人| 在线A级毛片免费视频| 九妹免费观看完整版| 亚洲AV成人无码一二三| 国产成人亚洲综合无码AⅤ| 日产精品久久久一区二区| CHINESE老女人老熟妇| 蜜臀AⅤ永久无码一区二区| 亚洲一区二区三区丝袜| 激情偷乱人伦小说视频最新章节| 小12国产萝裸体视频福利| 国产AV无码专区亚洲AV毛网站| 人人妻人人澡AV天堂香蕉| AV一本大道香蕉大在线| 妺妺和我裸睡玩我下春雨医生| 一本一道波多野结衣一区| 精品无人区卡卡卡卡卡二卡三乱码| 亚洲AV日韩AV无码AV一区二| 国产乱子伦视频在线播放| 玩弄人妻少妇老师美妇厨房| 国产AⅤ爽AV久久久久成人精品| 日本伊人色综合网| 八戒电影电影网电影网| 青草草97久热精品视频| JAPAN丰满少妇VIDEOS| 欧美性大战XXXXX久久久√| AAA少妇高潮大片免费看088| 女生裙子里面到底穿了啥| 99久久久国产精品消防器材| 拧花蒂尿用力按凸起喷水尿视频| 18款夜间禁用粉色短视频软件| 麻豆乱码1区2区新区| 中文字幕V亚洲日本在线| 免费无码成人AV在线播放| 2020无码天天喷水天天爽| 男人扒开女人内裤强吻桶进去| 4HU四虎永久在线影院| 女朋友特别闷骚很吸引别人| CAOPOREN免费精品视频| 欧洲精品码一区二区三区| 八戒八戒神马影院在线4| 日韩精品视频三区| 大学生被内谢粉嫩无套| 撕开奶罩揉吮奶头高潮视频| 国产精品久久精品国产| 性色欲情网站IWWW九文堂| 精品国偷自产在线视频| 亚洲综合另类小说色区色噜噜| 浪货趴办公桌~H揉秘书| 真实国产乱子伦沙发睡午觉| 欧美疯狂性受XXXXX另类| 被公侵犯怀孕的人妻中文字幕| 日产精品1卡二卡三卡| 国产成人AV一区二区三区在线观| 无人区码一码二码三码医生系列| 国色天香卡一卡2卡3卡4卡5| 亚洲人成在线观看无码| 免费光看午夜请高视频| ているの天堂资源WWW| 少妇伦子伦精品无吗| 国产青草视频在线观看| 亚洲欧洲中文日韩乱码AV | 44分钟欧美人与禽交片MP4| 人妻 中文 无码 JAVHD| 国产AV无码专区亚洲AV软件| 午夜精品一区二区三区免费视频| 经典国产乱子伦精品视频| 一夲道中文字幕AV高清片| 欧美一区二区放荡人妇| 给个网站2021年直接进入的| 亚洲AV无码成人精品区浪潮AV| 久久精品人妻系列无码专区| 696969大但人文艺术主题| 日韩人妻无码一区2区3区里沙| 国产精品无码成人午夜电影| 亚洲人成人无码WWW影院| 免费直播视频在线观看| 大香伊蕉在人线国产69| 亚洲AV鲁丝一区二区三区| 久欠精品国国产99国产精2| 暗交小拗女一区二区三区视频| 我把我的肥岳日出水来多少集 | x88AV在线观看ww| 无码精品人妻一区二区三区aV| 精品欧洲AV无码一区二区三区| 做AJ的姿势教程大全图| 肉体XXXXXⅠ8XXXX| 狠狠五月激情六月丁香| 99精品国产99久久久久久97 | 国产成人精品A视频一区| 亚洲色大成网站WWW在线观看 | YOUJIZZCOM中国熟妇| 性欧美丰满熟妇XXXX性久久久| 久人人爽人人爽人人片AV| 成人区人妻精品一区二区网站 | 狠狠色丁香久久婷婷综合_中| www.五月丁香| 国产精品美女乱子伦高| 亚洲欧美性爱视频在线| 欧美丰满熟妇性XXXX| 国产放荡对白视频在线观看| 亚洲欧美偷拍另类A∨| 欧美人与禽ZOZ0性伦交| 国产免费无遮挡吸乳视频在线观看 | 免费人成年激情视频在线观看| 豆国产97在线 | 韩国| 亚洲熟妇真实自拍另类| 人人玩人人添人人澡东莞| 好深好湿好硬顶到了好爽| HD2LINODE日本成熟IP| 亚洲A∨精品一区二区三区下载| 男人J进女人P免费视频在线直播| 国产精品边做奶水狂喷无码 | 少妇特殊按摩高潮爽翻天| 久久久久久精品成人鲁丝电影|