精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

SpringBoot前后端token自動(dòng)續(xù)期方案

開發(fā) 后端
后端服務(wù)會(huì)在過(guò)濾器中對(duì)?token?進(jìn)行校驗(yàn),包括合法性和是否過(guò)期。當(dāng)?token?已過(guò)期時(shí),后端會(huì)返回錯(cuò)誤信息,引導(dǎo)前端跳轉(zhuǎn)至登錄頁(yè)面,要求用戶重新登錄。

1. 背景

在前后端分離架構(gòu)下,用戶登錄成功后,后端服務(wù)會(huì)頒發(fā)一個(gè) token 作為用戶身份憑證。前端(如 Vue 應(yīng)用)在接收到 token 后,通常將其存儲(chǔ)到 LocalStorage,并在每次請(qǐng)求時(shí)通過(guò)請(qǐng)求頭攜帶該 token 訪問(wèn)后端服務(wù)。

后端服務(wù)會(huì)在過(guò)濾器中對(duì) token 進(jìn)行校驗(yàn),包括合法性和是否過(guò)期。當(dāng) token 已過(guò)期時(shí),后端會(huì)返回錯(cuò)誤信息,引導(dǎo)前端跳轉(zhuǎn)至登錄頁(yè)面,要求用戶重新登錄。

圖片圖片

這種機(jī)制雖然簡(jiǎn)單,但在實(shí)際使用中存在一個(gè)明顯的用戶體驗(yàn)問(wèn)題。例如:

? 用戶正在填寫一個(gè)較復(fù)雜的表單,提交時(shí)發(fā)現(xiàn) accessToken 已過(guò)期,不得不重新登錄并重新填寫;

? 用戶在持續(xù)操作系統(tǒng),但由于 accessToken 有固定時(shí)效,依舊會(huì)在某一時(shí)刻被強(qiáng)制退出。

這類場(chǎng)景都會(huì)造成較差的用戶體驗(yàn)。那么,有沒(méi)有辦法在用戶活躍操作時(shí),自動(dòng)延長(zhǎng) token 的有效期呢?

本文將介紹兩種常見的自動(dòng)續(xù)期方案:基于前端的刷新機(jī)制 和 基于后端的自動(dòng)續(xù)期機(jī)制

2. 自動(dòng)續(xù)期實(shí)現(xiàn)方案

2.1. 基于前端的自動(dòng)續(xù)期(Refresh Token)

如果系統(tǒng)采用 OAuth2 協(xié)議進(jìn)行認(rèn)證,并且支持 Refresh Token,就可以通過(guò)前端實(shí)現(xiàn)自動(dòng)續(xù)期。

典型的認(rèn)證響應(yīng)如下:

{
    "access_token": "eyJhbGciOiJFUzI1NiIs**********X6wrZHYKDxJkWwhdkrYg",
    "token_type": "Bearer",
    "expires_in": 7200,
    "refresh_token": "eyJhbGciOiJFUzI1NiIs**********XXOYOZz1mfgIYHwM8ZJA", 
    "refresh_token_expires_in": 604800
    ......
}

說(shuō)明:

access_token:訪問(wèn)令牌(通常有效期 1~2 小時(shí)),前端調(diào)用后端接口時(shí)使用。

refresh_token:刷新令牌(有效期較長(zhǎng),常見 7~30 天),用于在 access_token 過(guò)期時(shí)獲取新的 access_token

此時(shí),可以在前端通過(guò) 響應(yīng)攔截器 自動(dòng)處理續(xù)期邏輯:

// Axios響應(yīng)攔截器實(shí)現(xiàn)自動(dòng)續(xù)期
axios.interceptors.response.use(
    (response) => response,
    async (error) => {
        const originalRequest = error.config;
        
        if (error.response?.status === 401 && !originalRequest._retry) {
            originalRequest._retry = true;
            try {
                const refreshToken = localStorage.getItem('refresh_token');
                const refreshResponse = await axios.post('/auth/refresh', {
                    refresh_token: refreshToken
                });
                
                // 更新Token
                localStorage.setItem('access_token', refreshResponse.data.access_token);
                localStorage.setItem('refresh_token', refreshResponse.data.refresh_token);
              
                // 重新發(fā)送原始請(qǐng)求
                originalRequest.headers.Authorization = `Bearer ${refreshResponse.data.access_token}`;
                returnaxios(originalRequest);
            } catch (refreshError) {
                // 續(xù)期失敗,清除Token并跳轉(zhuǎn)登錄
                localStorage.clear();
                window.location.href = '/login';
                returnPromise.reject(refreshError);
            }
        }
        returnPromise.reject(error);
    }
);

這種方式的優(yōu)點(diǎn)是清晰易懂,基于 OAuth2 標(biāo)準(zhǔn)實(shí)現(xiàn);缺點(diǎn)是必須有 refresh_token 機(jī)制 支持,否則無(wú)法使用。

2.2 基于后端實(shí)現(xiàn)自動(dòng)續(xù)期

在很多項(xiàng)目中,認(rèn)證并未采用雙 token 模式,而是只有一個(gè) accessToken(通常為 JWT)。此時(shí),可以在后端引入一層“間接認(rèn)證”來(lái)實(shí)現(xiàn)自動(dòng)續(xù)期。

實(shí)現(xiàn)思路如下:

登錄時(shí)生成雙 token

? 登錄成功后生成一個(gè) uuidToken(隨機(jī) UUID),同時(shí)生成一個(gè) accessToken

? 將 uuidToken 作為 key,accessToken(及用戶信息)作為 value 存入緩存,緩存過(guò)期時(shí)間為 accessToken 有效期的 2 倍;

? 返回 uuidToken 給前端。

注意:JWT 本身長(zhǎng)度較長(zhǎng),不適合作為緩存 key,因此使用短 UUID 替代。

請(qǐng)求攔截與校驗(yàn)

? 前端請(qǐng)求時(shí)攜帶 uuidToken

? 后端通過(guò) uuidToken 從緩存中獲取 accessToken

? 若緩存不存在,則判定為用戶長(zhǎng)時(shí)間未操作,要求重新登錄;

? 若 accessToken 已過(guò)期,但 uuidToken 未過(guò)期,說(shuō)明用戶仍在活躍操作,此時(shí)后端可為其生成新的 accessToken 并覆蓋緩存,從而實(shí)現(xiàn)自動(dòng)續(xù)期。

前端無(wú)感知

? 前端始終只持有 uuidToken

accessToken 的變化僅在后端進(jìn)行更新,對(duì)前端無(wú)影響。

登錄邏輯示例

public String login(String userName, String password) {
    StringuuidToken= UUID.randomUUID().toString();

    SysUsersysUser= userService.getUserByUserName(userName);
    // ...認(rèn)證邏輯...

    StringaccessToken= JwtUtil.createJWT(sysUser);

    LoginUserVOloginUserVO=newLoginUserVO();
    loginUserVO.setUserAccount(sysUser.getUserId());
    loginUserVO.setName(sysUser.getName());
    loginUserVO.setRole("Manager");
    loginUserVO.setAccessToken(accessToken);

    // 存儲(chǔ)用戶信息至緩存
    userTokenService.storeUserToken(uuidToken, loginUserVO);

    return uuidToken;
}

后端請(qǐng)求過(guò)濾器示例

@Slf4j
@Component
publicclassTokenFilterextendsOncePerRequestFilter {
    @Override
    protectedvoiddoFilterInternal(HttpServletRequest request,
                                    HttpServletResponse response,
                                    FilterChain filterChain)throws IOException {
        try {
            StringrequestPath= request.getRequestURI();

            // 白名單放行
            if (isWhiteListPath(requestPath)) {
                filterChain.doFilter(request, response);
                return;
            }

            // 獲取UUID Token
            StringuuidToken= getAccessToken(request);
            if (uuidToken == null) {
                sendUnauthorizedResponse(response, "Missing token");
                return;
            }

            // 獲取用戶信息
            LoginUserVOloginUserVO= userTokenService.getUserByToken(uuidToken);
            if (loginUserVO == null) {
                sendUnauthorizedResponse(response, "Token expired or invalid");
                return;
            }

            // 檢查并續(xù)期
            loginUserVO = userTokenService.checkAndRefreshIfNeeded(uuidToken, loginUserVO);

            // 設(shè)置用戶上下文
            UserContextHolder.setContext(UserContext.fromUserToken(uuidToken, loginUserVO));

            filterChain.doFilter(request, response);
        } finally {
            UserContextHolder.clearContext();
        }
    }

    private String getAccessToken(HttpServletRequest request) {
        Stringtoken= request.getHeader("Authorization");
        return (token != null) ? token : request.getParameter("Authorization");
    }
}

3. 總結(jié)

在前后端分離的應(yīng)用中,token 的續(xù)期機(jī)制直接影響用戶體驗(yàn)。

  • 基于前端的方案(Refresh Token)適用于標(biāo)準(zhǔn) OAuth2 認(rèn)證體系,方案清晰,但依賴協(xié)議支持;
  • 基于后端的方案(UUID Token + 自動(dòng)刷新)則適用于只有單一 accessToken 的場(chǎng)景,能在后端無(wú)感知地為用戶自動(dòng)續(xù)期。

在實(shí)際項(xiàng)目中,應(yīng)根據(jù)系統(tǒng)架構(gòu)和認(rèn)證機(jī)制選擇合適的續(xù)期方案,從而在安全性和用戶體驗(yàn)之間取得平衡。

責(zé)任編輯:武曉燕 來(lái)源: JAVA日知錄
相關(guān)推薦

2025-08-18 08:26:14

2022-05-27 10:40:04

前后端權(quán)限控制設(shè)計(jì)

2019-06-12 19:00:14

前后端分離AppJava

2015-11-12 10:32:27

前端后端分離

2025-02-10 08:39:17

2021-03-03 13:25:35

CookieSessionToken

2024-12-31 08:54:38

2023-09-21 10:44:41

Web服務(wù)Swagger前端

2023-02-08 16:29:58

前后端開發(fā)

2021-09-18 09:45:33

前端接口架構(gòu)

2018-10-23 14:24:10

2022-04-06 07:50:57

JWT后端Spring

2015-01-08 10:08:03

前后端分離

2020-09-25 11:50:12

前后端分離架構(gòu)Web

2021-10-20 18:21:18

項(xiàng)目技術(shù)開發(fā)

2014-04-18 14:43:07

前后端分離NodeJS

2019-07-09 05:44:35

前后端分離架構(gòu)接口規(guī)范

2020-02-13 09:52:48

加密前后端https

2017-02-15 10:18:32

架構(gòu)前后端分離

2019-12-04 08:44:59

前后端分離開發(fā)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

日本美女高清在线观看免费| 欧美成人aaaaⅴ片在线看| 国产黄色一区| 亚洲三级在线看| 国产日韩精品久久| 亚洲乱码国产乱码精品| 亚洲成人最新网站| 亚洲精品国产美女| 国产xxxxx视频| av中文字幕在线播放| 91在线精品秘密一区二区| 国产精品丝袜高跟| 日本三级视频在线| 日韩免费高清| 日韩av中文字幕在线免费观看| 黄色三级视频片| 2020av在线| 综合色天天鬼久久鬼色| 久久天堂国产精品| 国产国语亲子伦亲子| 日韩在线一区二区三区| 久久久久久一区二区三区| 黄色三级生活片| 好吊妞视频这里有精品| 在线91免费看| 爆乳熟妇一区二区三区霸乳| 欧美人体视频xxxxx| 国产精品卡一卡二| 欧美日韩一区二| 日本xxxxwww| 激情成人综合网| 国产97色在线| 久久国产精品免费看| 欧美日韩四区| 精品国产欧美一区二区三区成人 | 国产一级精品视频| 在线观看国产精品入口| 视频在线一区二区| 日韩免费成人av| 婷婷精品视频| 亚洲成年人在线播放| 国产裸体视频网站| 91精品网站在线观看| 欧美色老头old∨ideo| 国产xxxxx在线观看| xxxx在线视频| 亚洲成a人在线观看| 男女爱爱视频网站| 黄在线免费看| 亚洲欧洲av在线| 亚洲一区高清| 91在线观看| 国产精品五月天| 天天久久人人| av播放在线| 中文字幕 久热精品 视频在线| 欧美午夜欧美| 国产高清在线看| 国产日产欧美精品一区二区三区| 欧美精品亚洲精品| 邻居大乳一区二区三区| 国产欧美日韩精品a在线观看| 欧美日韩国产免费一区二区三区| 欧洲亚洲精品视频| 国产欧美一区二区三区沐欲| 欧美一区二区三区在线播放 | 怡红院av亚洲一区二区三区h| 牛牛精品视频在线| 性久久久久久久久久久久| 成人网站免费观看入口| 涩涩在线视频| 欧洲在线/亚洲| 国产成人美女视频| 亚洲2区在线| 日韩av在线导航| 在线免费看黄视频| 久久一区91| 美日韩精品免费视频| 久艹视频在线观看| 香蕉av777xxx色综合一区| 国产不卡在线观看| 国产乱子伦精品无码码专区| 国产成人啪午夜精品网站男同| 国产精品一区二区三区精品| 青青久草在线| 中文字幕视频一区| 欧美午夜性视频| 综合在线影院| 91精品国产综合久久久久| 美女又黄又免费的视频| 亚欧洲精品视频在线观看| 尤物九九久久国产精品的分类| 色婷婷粉嫩av| 激情久久五月| 国产精品美女无圣光视频| 国产精品久久久久久久久久久久久久久久久久 | 国产综合激情| 日本午夜人人精品| jizz国产视频| 久久久久国产成人精品亚洲午夜| 天天爱天天做天天操| h片在线观看视频免费免费| 欧美性受xxxx黑人xyx性爽| 日韩精品xxx| 九九视频免费观看视频精品 | 四虎免费在线视频| 午夜一级在线看亚洲| 91人成网站www| 四虎成人免费在线| 亚洲精品福利视频网站| 日日摸天天爽天天爽视频| 国产美女亚洲精品7777| 亚洲人午夜色婷婷| 国产真人真事毛片| 蜜臀av性久久久久蜜臀av麻豆| 成人av免费在线看| 日本中文在线| 91成人国产精品| 国产一卡二卡三卡四卡| 97精品一区| 国产精品wwww| 亚洲av成人无码网天堂 | 日本一区二区欧美| 久久av中文字幕片| 日本黄网免费一区二区精品| 精精国产xxxx视频在线中文版| 欧美性猛交xxxx黑人交| 91久久免费视频| 亚洲一区国产| 国产精品自拍首页| 特级毛片在线| 欧美一卡二卡三卡| 国产wwwwxxxx| 日韩av一区二区在线影视| 久久艳妇乳肉豪妇荡乳av| 男女羞羞视频在线观看| 91精品国产一区二区| 成人信息集中地| 视频一区视频二区中文| 久久亚洲精品欧美| 69av成人| 精品粉嫩超白一线天av| 中文字幕av免费在线观看| 美国三级日本三级久久99| 日韩高清dvd| 三上悠亚国产精品一区二区三区| 亚洲精品中文字幕有码专区| 黄网在线观看视频| 91日韩精品一区| 777精品久无码人妻蜜桃| 国产精品网址| 久久久亚洲国产| 亚洲国产成人在线观看| 亚洲午夜电影在线观看| www.555国产精品免费| 好看不卡的中文字幕| 粉嫩av免费一区二区三区| 深夜国产在线播放| 精品va天堂亚洲国产| 色网站在线播放| 91在线观看下载| 免费大片在线观看| 日韩欧美午夜| 91在线播放国产| 超免费在线视频| 日韩精品一二三四区| 亚洲熟妇无码乱子av电影| 日本一区二区视频在线| 亚洲妇熟xx妇色黄蜜桃| 亚洲一级淫片| 国产一区在线观| 欧美极品影院| 日韩亚洲综合在线| 性生交大片免费看女人按摩| 亚洲成人动漫av| 国产jk精品白丝av在线观看| 美国十次了思思久久精品导航| 色中文字幕在线观看| 国内露脸中年夫妇交换精品| 日本亚洲精品在线观看| h片在线免费观看| 亚洲国产日韩欧美在线图片| 中文字幕乱码在线观看| 亚洲精品伦理在线| 精品少妇人妻一区二区黑料社区| 免费高清视频精品| 97超碰国产精品| jizzjizz欧美69巨大| 92看片淫黄大片看国产片| 黄在线观看免费网站ktv| 中文字幕亚洲精品| 亚洲精品视频网| 在线一区二区三区四区| 久久久久久久蜜桃| 中文字幕国产精品一区二区| 免费啪视频在线观看| 视频一区在线播放| 免费看欧美黑人毛片| 日韩黄色大片| 国语精品免费视频| 婷婷久久综合九色综合99蜜桃| 久久久久久久久久国产| 色的视频在线免费看| 亚洲黄色有码视频| 国产一区二区三区成人| 欧美午夜精品久久久久久人妖 | 欧美色偷偷大香| 男人天堂中文字幕| 椎名由奈av一区二区三区| aaaaa级少妇高潮大片免费看| 国产精一区二区三区| 精品免费国产一区二区| 激情综合在线| 潘金莲一级淫片aaaaa免费看| 久操成人av| 国产综合欧美在线看| av日韩久久| 国产精品www| 热三久草你在线| 欧美激情伊人电影| 精品国产99久久久久久| 最近2019年中文视频免费在线观看 | 日韩影视精品| 午夜a一级毛片亚洲欧洲| 春色成人在线视频| 国色天香久久精品国产一区| 国产精品入口尤物| 成人软件在线观看| 日韩av免费看| 色偷偷偷在线视频播放| 91精品国产91久久久| 美足av综合网| 欧美韩国理论所午夜片917电影| 黄色小网站在线观看| 在线看片第一页欧美| 国产资源在线看| 亚洲欧洲在线免费| 人操人视频在线观看| 国产视频精品一区二区三区| 免费成人在线看| 精品剧情v国产在线观看在线| 国产免费黄色大片| 日韩一级高清毛片| 精品女同一区二区三区| 日韩欧美国产一区在线观看| 99久久99久久久精品棕色圆| 日韩一二三区不卡| www.麻豆av| 精品捆绑美女sm三区| 欧美特黄一级视频| 日韩电影免费观看中文字幕| 五月婷婷六月丁香| 亚洲女人天堂成人av在线| 邻居大乳一区二区三区| 国产一区二区三区视频| 一广人看www在线观看免费视频| 在线观看亚洲区| 欧美尤物美女在线| 毛片精品免费在线观看| 在线网址91| 久久人人爽人人爽人人片av高清| 日韩伦理精品| 国产成人精品在线观看| 免费视频观看成人| 亚洲影院高清在线| 红杏aⅴ成人免费视频| 蜜桃91精品入口| 欧美性感美女一区二区| 国产免费色视频| 在线观看一区视频| 韩国一区二区av| 另类中文字幕网| 日韩高清一二三区| 久久久激情视频| 五月天婷婷丁香网| 亚洲一区二区三区在线播放| 久久青青草视频| 欧美色中文字幕| 亚洲国产精品欧美久久| 亚洲一区二区福利| 快射av在线播放一区| 久久久久久久网站| 欧美在线va视频| 成人性色av| 精品不卡一区| 日韩精品一区二区免费| 可以看av的网站久久看| 青青草精品在线| 99久久综合99久久综合网站| 亚洲一级片在线播放| 亚洲一区二区成人在线观看| 午夜久久久久久久久久影院| 日韩欧美中文字幕一区| 暖暖视频在线免费观看| 精品视频9999| 国产成人a视频高清在线观看| 成人高清在线观看| 欧美色图激情小说| 你真棒插曲来救救我在线观看| 日韩国产成人精品| 高清中文字幕mv的电影| |精品福利一区二区三区| 91久久国产视频| 91麻豆精品国产91久久久久| 天堂av在线播放| 米奇精品一区二区三区在线观看| 欧美xo影院| 国产日韩精品推荐| 久久精品欧美一区| 无码少妇一区二区三区芒果| 成人精品国产一区二区4080 | 午夜在线电影亚洲一区| 国产精品一区二区免费视频| 亚洲天堂成人在线视频| 超碰在线97国产| 亚洲一区免费网站| 日本一区二区三区视频| 日本不卡在线观看视频| 国产91对白在线观看九色| 97在线观看免费高| 欧美三级三级三级| 狠狠v欧美ⅴ日韩v亚洲v大胸| 91国产中文字幕| julia中文字幕一区二区99在线| 中文字幕日韩精品久久| 久久久水蜜桃av免费网站| 国产一卡二卡三卡四卡| 亚洲午夜视频在线观看| 国产成人精品一区二三区四区五区| 丝袜亚洲另类欧美重口| 欧美三区四区| 日韩视频在线播放| 久久午夜av| 国产精品高清无码在线观看| 婷婷开心久久网| 欧美一区二区三区黄片| 久久久久久久久久亚洲| 超碰成人97| 国产精品久久久久久久久电影网| 国内精品在线播放| 日本在线一级片| 欧美一卡2卡三卡4卡5免费| а√资源新版在线天堂| 91精品黄色| 狠狠色综合网| 成人在线电影网站| 精品国产91乱高清在线观看 | 国产三级欧美三级日产三级99 | 色99中文字幕| 人人爽香蕉精品| 日本女人性生活视频| 欧美久久久久久蜜桃| 国内精品久久久久久野外| 亚洲a∨日韩av高清在线观看| 欧美/亚洲一区| 熟女人妻一区二区三区免费看| 亚洲综合色噜噜狠狠| 天堂8在线视频| 国产精品18久久久久久麻辣| 日韩免费视频| 交换做爰国语对白| 亚洲一区二区三区四区的| 视频二区在线观看| 国产成人精品在线| 亚洲欧洲美洲一区二区三区| 97人妻精品一区二区三区免费| 欧美视频在线免费看| 91在线导航| 国产富婆一区二区三区| 亚洲欧美久久| 中国美女黄色一级片| 日韩欧美中文字幕公布| 男女羞羞在线观看| 日韩欧美精品一区二区| 激情综合色综合久久综合| 国产极品在线播放| 亚洲一级黄色片| 综合伊人久久| 成人一区二区三| 亚洲精品欧美综合四区| 亚欧在线观看视频| 成人精品一区二区三区| 日韩午夜av在线| 欧美色图17p| 亚洲成人性视频| 日本成人一区二区| 少妇无码av无码专区在线观看| 国产精品少妇自拍| 国 产 黄 色 大 片| 国产精品久久久久久一区二区| 欧美一区综合| 37p粉嫩大胆色噜噜噜| 欧美一级二级在线观看| 欧美三级精品| 国产精品无码免费专区午夜| 国产欧美一区二区精品仙草咪| av免费在线不卡| 国产精品看片资源| 日韩午夜av在线| 丰满少妇高潮久久三区|