精品欧美一区二区三区在线观看 _久久久久国色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)

成人在线一区二区| 国产a久久精品一区二区三区| 蜜桃国内精品久久久久软件9| 综合久久久久久久| 国产成人在线一区| 菠萝菠萝蜜网站| 国产成人精品毛片| av一区二区在线播放| 亚洲精品成人天堂一二三| 国产精品久久久久久久久久久久久| 精品1卡二卡三卡四卡老狼| 成人在线播放| 99久久婷婷| 欧美调教femdomvk| 日韩久久久久久久久久久久久| 精品无码黑人又粗又大又长| 99精品女人在线观看免费视频| 国产欧美日韩激情| 国产91在线播放九色快色| 国产又粗又猛又色| 91av久久| av网站免费线看精品| 欧美激情a在线| 香蕉视频1024| 92久久精品| 国产精品三级视频| 成人精品久久一区二区三区| 日本成人精品视频| 色8久久久久| |精品福利一区二区三区| 国产乱码精品一区二区三区中文 | 国产3p露脸普通话对白| 99国产精品久久久久99打野战| 青青草国产免费一区二区下载 | 国产男男gay体育生网站| 午夜在线播放视频欧美| 日韩高清有码在线| 国产又大又硬又粗| 国产小视频免费在线观看| 性欧美xxxx大乳国产app| 超薄丝袜一区二区| 亚洲成人精品在线播放| 伊人在线视频| 黑人精品欧美一区二区蜜桃| 精品中文字幕乱| 日批视频免费看| 国内不卡的一区二区三区中文字幕| 久久综合精品国产一区二区三区| 国产成人一区二区三区| 日产电影一区二区三区| 国产精品亚洲二区| 日韩精品一二三四区| 天天操天天爱天天爽| 91福利在线视频| 国产电影精品久久禁18| 亚州成人av在线| 欧美a在线播放| 99ri日韩精品视频| 欧美日韩一区二区电影| 国产人妻人伦精品| 欧美亚洲日本| 国产一区二区三区在线观看免费 | 久久久久久久久久久久久久免费看| 久久在线视频免费观看| 日韩丝袜美女视频| 欧美牲交a欧美牲交aⅴ免费下载| 永久免费毛片在线播放| 国产精品传媒视频| 久久99久久精品国产| 中文字幕人妻精品一区| 精品999成人| 伊人久久久久久久久久久| 18深夜在线观看免费视频| 欧美大片1688| 亚洲自拍与偷拍| 日韩精品第一页| 番号集在线观看| 中文字幕亚洲不卡| 国产精品igao激情视频| 国产经典自拍视频在线观看| 国产日韩av一区| 国产精品一区二区欧美| 性插视频在线观看| 懂色av一区二区三区蜜臀| 国产精品入口尤物| 99精品人妻国产毛片| 国户精品久久久久久久久久久不卡| 国产小视频国产精品| 蜜臀av粉嫩av懂色av| 欧美大片网址| 日韩精品专区在线影院重磅| 色多多视频在线播放| 色成人综合网| 亚洲电影免费观看高清| 亚洲 自拍 另类 欧美 丝袜| 国产一区福利| 欧美大黄免费观看| 菠萝菠萝蜜网站| 久久激情电影| 一区二区三区精品99久久| 国产午夜精品理论片在线| 欧洲grand老妇人| 不用播放器成人网| 国产亚洲欧美在线精品| 国产精一品亚洲二区在线视频| 国产精品亚洲片夜色在线| 国产精品久免费的黄网站| 亚洲啪啪91| 久久久天堂国产精品女人| 成年人av电影| 婷婷综合五月| 91成人在线视频| www.国产色| 国产亚洲精品v| 欧美一区二区.| 手机看片久久久| 国产精品综合一区二区三区| 欧美日韩精品免费看| 欧美另类自拍| 欧美韩国日本综合| 国产高清av在线播放| 亚洲精品大全| 国产一区二区三区在线观看视频 | 大地资源二中文在线影视观看| 久久久久久影院| 久久天天躁日日躁| 在线观看国产区| 麻豆传媒一区二区三区| 国产这里只有精品| 国产熟女一区二区三区四区| 久久精品男人的天堂| 99久久国产综合精品五月天喷水| 中文成人在线| 深夜福利国产精品| 麻豆精品一区二区三区视频| 日本系列欧美系列| 91在线中文字幕| 黄频在线免费观看| 91年精品国产| 亚洲午夜精品国产| av观看在线| 欧美日韩中文字幕日韩欧美| 丰满少妇在线观看| 久久99国产精品视频| 1769国内精品视频在线播放| 日韩一级在线播放| 久久久www免费人成精品| 亚洲一区二区在线看| 不卡av播放| 91.麻豆视频| 800av在线播放| 在线观看日韩av电影| 国产v亚洲v天堂无码| 毛片在线播放网址| 欧美日韩亚洲网| 91精品视频国产| 婷婷成人综合| 久久在线精品视频| 国产欧美久久久精品免费| 自拍偷拍亚洲综合| 日韩欧美理论片| 激情欧美一区| 久久久免费看| 欧美××××黑人××性爽| 国产一区二区激情| 91av久久久| www一区二区| 精品www久久久久奶水| 高清在线一区二区| 欧美第一黄色网| 人妻一区二区三区四区| 狠狠久久五月精品中文字幕| 午夜时刻免费入口| 亚洲欧洲日本mm| 麻豆精品蜜桃一区二区三区| 91精品久久| 亚洲第一福利视频| 亚洲欧美日韩一区二区三区四区| 高清在线不卡av| 自拍视频一区二区三区| 成人美女大片| 少妇av一区二区三区| 亚洲AV无码一区二区三区性 | 美国av一区二区三区| 成人免费福利| 亚洲高清免费观看高清完整版| 日本少妇在线观看| 国产色综合一区| 小日子的在线观看免费第8集| 一本色道久久综合| 91久久偷偷做嫩草影院| 蜜芽在线免费观看| 在线免费不卡视频| 少妇精品一区二区三区| 亚洲精品看片| 天堂精品视频| 国精产品一区一区三区四川| 久久精品视频亚洲| 夜夜躁狠狠躁日日躁av| 国产人久久人人人人爽| 亚洲精品久久久久久| 视频一区二区三区入口| 欧美男人的天堂| 成人在线精品| 日本韩国欧美精品大片卡二| 深夜福利在线看| 欧美日韩亚洲成人| 538精品在线观看| 亚洲国产精品成人综合 | 香蕉伊大人中文在线观看| xxav国产精品美女主播| 国产黄色免费视频| 亚洲一区在线观看免费观看电影高清 | 亚洲夜夜综合| 日韩欧美国产午夜精品| 欧美一级淫片免费视频黄| 久久综合狠狠综合久久综合88| 午夜视频在线网站| 一区二区电影| 国产精品一区二区三区观看| 黄色成人小视频| 久久精品国产亚洲精品| 毛片在线播放网址| 亚洲精品福利免费在线观看| 国产又黄又猛又粗又爽| 亚洲综合色在线| 好吊日在线视频| 粉嫩aⅴ一区二区三区四区| 尤物国产在线观看| 欧美激情91| 精品国产免费人成电影在线观...| 白浆视频在线观看| 亚洲视频999| 国产精品区在线观看| 亚洲日本丝袜连裤袜办公室| 挪威xxxx性hd极品| 国产不卡一区视频| 黄色片子免费看| 中国女人久久久| 国产精品专区在线| 色婷婷色综合| 亚洲精品国产系列| 精品国产鲁一鲁****| 国产日本欧美一区| 另类一区二区| 成人免费在线视频网站| 精品久久久久久久久久岛国gif| 成人午夜激情网| 欧美在线在线| 日本精品久久久久影院| 黄毛片在线观看| 国产91精品高潮白浆喷水| 涩涩涩在线视频| 久久精品国产2020观看福利| √天堂资源地址在线官网| 最近更新的2019中文字幕| 1024免费在线视频| 久久久精品一区二区三区| 菠萝蜜视频国产在线播放| 美女视频久久黄| 国产福利在线| 在线看欧美日韩| 久操视频在线播放| 亚洲女同性videos| 亚洲h视频在线观看| 精品免费日韩av| 亚洲中文字幕在线一区| 欧美男人的天堂一二区| 手机在线看片1024| 欧美日韩一区三区四区| 国产农村妇女毛片精品久久| 日韩你懂的电影在线观看| 色婷婷激情五月| 日韩午夜av电影| 四虎成人免费在线| 少妇激情综合网| 丁香花高清在线观看完整版| 久久精品欧美视频| av美女在线观看| 国产精品嫩草影院一区二区| 国产精品视频一区视频二区| 国产成人女人毛片视频在线| 精品中文一区| 黄色片免费在线观看视频| 性欧美videos另类喷潮| 99九九精品视频| 久久综合色鬼综合色| 美女视频久久久| 精品美女久久久久久免费| 九九热这里有精品视频| 亚洲人亚洲人成电影网站色| 国产在线视频在线观看| 亚洲精品视频在线看| 乱老熟女一区二区三区| 亚洲国产精品自拍| 精品无码一区二区三区电影桃花| 日韩欧美亚洲综合| a级片在线播放| 国产亚洲视频中文字幕视频| 久久99亚洲网美利坚合众国| 欧美精品日韩www.p站| 中文日产幕无线码一区二区| 亚洲在线一区二区| 教室别恋欧美无删减版| 国产欧美精品aaaaaa片| 国产一在线精品一区在线观看| 无遮挡又爽又刺激的视频 | 自拍视频一区二区| 亚洲婷婷国产精品电影人久久| 日韩久久久久久久久| 欧美一三区三区四区免费在线看| 中文字幕一区二区人妻痴汉电车| 精品久久久久久久一区二区蜜臀| h视频在线免费| 日韩小视频在线观看| 手机在线理论片| 不卡视频一区二区| 里番精品3d一二三区| 久久国产精品高清| 欧美激情综合| 波多野结衣综合网| 国产揄拍国内精品对白| 亚洲黄色免费视频| 中文字幕一区二区三区蜜月 | 91精品国产综合久久久久| 邻家有女韩剧在线观看国语| 国内精品一区二区三区四区| 一区二区三区日本视频| 亚洲成人18| 日韩av网站免费在线| 在线观看福利片| 亚洲第一偷拍| 亚洲女性喷水在线观看一区| 日韩av综合在线| 日韩视频免费观看高清在线视频| 男人和女人做事情在线视频网站免费观看| 奇米成人av国产一区二区三区| 极品束缚调教一区二区网站 | 国产精品制服诱惑| 亚洲调教视频在线观看| 欧美一级片在线免费观看| 亚洲美女视频在线| 精品人妻伦一区二区三区久久| 欧美一区二区三区在线观看| 在线观看a视频| 国产欧美日韩91| 91一区在线| 四虎成人在线播放| 亚洲激情图片一区| 亚洲AV无码成人片在线观看| 久久999免费视频| 99re91这里只有精品| 青青青在线视频播放| www..com久久爱| 国产在线观看黄色| 在线观看日韩www视频免费| 免费在线成人激情电影| 国产91视觉| 亚洲精品孕妇| 中文字幕在线观看的网站| 色婷婷狠狠综合| 亚洲国产欧美另类| 久久久久五月天| 亚洲成人一品| 久操手机在线视频| hitomi一区二区三区精品| 日本韩国欧美中文字幕| 亚洲无限av看| 91成人app| 男人插女人视频在线观看| 久久婷婷国产综合国色天香| 中日韩在线观看视频| 久久久精品网站| 欧美黄色网视频| 国产三级国产精品国产专区50| 亚洲精品视频在线| 天堂91在线| 91精品国产综合久久久久久蜜臀 | 99re6在线观看| 91在线一区二区| 免费网站观看www在线观| 亚洲福利视频专区| 影音成人av| 成人小视频在线观看免费| 久久午夜羞羞影院免费观看| 一级黄色片网站| 97视频免费看| 91成人国产| 中文字幕免费视频| 日韩欧美一区二区三区在线| 中文字幕在线高清| 久久免费一级片| 国产日韩欧美高清| 亚洲精品国产一区二| 国产精品国产福利国产秒拍| 欧美日韩理论| 肉色超薄丝袜脚交69xx图片 | 91免费看网站| 日韩精品乱码免费| 爱爱免费小视频|