SpringBoot+Vue中的Token續(xù)簽機(jī)制
在這個(gè)示例中,我們將使用Spring Boot作為后端框架,Vue作為前端框架,演示如何在全棧應(yīng)用中實(shí)現(xiàn)長(zhǎng)短Token的續(xù)簽。
1. Spring Boot后端
1.1 長(zhǎng)Token的生成
在Spring Boot中,我們首先創(chuàng)建一個(gè)服務(wù)來(lái)生成JWT Token。使用jjwt
庫(kù),確保在pom.xml
文件中添加以下依賴:
<dependency> <groupId>io.jsonwebtoken</groupId> <artifactId>jjwt</artifactId> <version>0.9.1</version> </dependency>
然后,創(chuàng)建JwtTokenService
服務(wù):
import io.jsonwebtoken.Jwts; import io.jsonwebtoken.SignatureAlgorithm; import org.springframework.stereotype.Service; import java.util.Date; @Service public class JwtTokenService { private String secretKey = "your_secret_key"; public String generateLongToken(String username) { long expiration = 7 * 24 * 60 * 60 * 1000; // 7 days return Jwts.builder() .setSubject(username) .setExpiration(new Date(System.currentTimeMillis() + expiration)) .signWith(SignatureAlgorithm.HS256, secretKey) .compact(); } // ... 其他方法 ... }
1.2 短Token的生成
添加生成短Token的方法:
public String generateShortToken(String username) { long expiration = 15 * 60 * 1000; // 15 minutes return Jwts.builder() .setSubject(username) .setExpiration(new Date(System.currentTimeMillis() + expiration)) .signWith(SignatureAlgorithm.HS256, secretKey) .compact(); }
1.3 Token續(xù)簽
創(chuàng)建一個(gè)方法用于續(xù)簽Token:
public String renewToken(String oldToken) { // 解析舊Token獲取用戶名 String username = Jwts.parser() .setSigningKey(secretKey) .parseClaimsJws(oldToken) .getBody() .getSubject(); // 生成新的短Token return generateShortToken(username); }
2. Vue前端
在Vue應(yīng)用中,確保每次請(qǐng)求時(shí)都附加Token,并在需要時(shí)更新Token。
2.1 處理Token過(guò)期
在Vue應(yīng)用中,可以使用攔截器來(lái)檢查Token是否過(guò)期,如果過(guò)期則觸發(fā)續(xù)簽流程:
// main.js 或者其他入口文件 import Vue from 'vue'; import axios from 'axios'; // 設(shè)置axios攔截器 axios.interceptors.request.use( config => { // 在發(fā)送請(qǐng)求之前做些什么 const token = localStorage.getItem('token'); if (token) { // 如果存在令牌,將其添加到請(qǐng)求頭 config.headers.Authorization = `Bearer ${token}`; } return config; }, error => { // 對(duì)請(qǐng)求錯(cuò)誤做些什么 return Promise.reject(error); } ); axios.interceptors.response.use( response => { // 對(duì)響應(yīng)數(shù)據(jù)做些什么 return response; }, error => { // 對(duì)響應(yīng)錯(cuò)誤做些什么 const originalRequest = error.config; if (error.response.status === 401 && !originalRequest._retry) { // 如果響應(yīng)狀態(tài)為401(未授權(quán))并且尚未重試過(guò) originalRequest._retry = true; // 發(fā)送續(xù)期請(qǐng)求 return axios.post('/api/renew-token') .then(response => { // 更新本地存儲(chǔ)的令牌 updateLocalStorageToken(response.data.token); // 重新發(fā)送原始請(qǐng)求 return axios(originalRequest); }); } return Promise.reject(error); } ); // 將axios添加到Vue的原型中,使其在組件中可以直接使用 Vue.prototype.$http = axios;
通過(guò)這個(gè)攔截器,我們?cè)诿看握?qǐng)求時(shí)就可以檢查Token是否過(guò)期,如果過(guò)期則觸發(fā)續(xù)簽流程。這樣就實(shí)現(xiàn)了在Vue前端應(yīng)用中的Token續(xù)簽機(jī)制。
到此這篇關(guān)于SpringBoot+Vue中的Token續(xù)簽機(jī)制的文章就介紹到這了,更多相關(guān)SpringBoot Vue Token續(xù)簽內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot 自定義注解異步記錄復(fù)雜日志詳解
這篇文章主要為大家介紹了SpringBoot 自定義注解異步記錄復(fù)雜日志詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09Java爬蟲(chóng)(Jsoup與WebDriver)的使用
這篇文章主要介紹了Java爬蟲(chóng)(Jsoup與WebDriver)的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12java如何實(shí)現(xiàn)抽取json文件指定字段值
這篇文章主要介紹了java如何實(shí)現(xiàn)抽取json文件指定字段值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。2022-06-06Java中List使用stream流轉(zhuǎn)成map的幾種方式詳解
Stream是Java8中處理集合的關(guān)鍵抽象概念,它可以指定你希望對(duì)集合進(jìn)行的操作,可以執(zhí)行非常復(fù)雜的查找、過(guò)濾和映射數(shù)據(jù)等操作,下面這篇文章主要給大家介紹了關(guān)于Java中List使用stream流轉(zhuǎn)成map的幾種方式,需要的朋友可以參考下2023-04-04SpringBoot實(shí)戰(zhàn)之實(shí)現(xiàn)結(jié)果的優(yōu)雅響應(yīng)案例詳解
這篇文章主要介紹了SpringBoot實(shí)戰(zhàn)之實(shí)現(xiàn)結(jié)果的優(yōu)雅響應(yīng)案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09springboot接口加簽驗(yàn)簽常見(jiàn)的幾大問(wèn)題及解決過(guò)程
在SpringBoot框架中通過(guò)自定義注解實(shí)現(xiàn)加簽驗(yàn)簽功能是一個(gè)非常實(shí)用的技術(shù),本文主要介紹了使用SpringBoot進(jìn)行加簽驗(yàn)簽時(shí)可能遇到的幾個(gè)問(wèn)題,包括請(qǐng)求流重復(fù)讀取問(wèn)題、控制器中文件參數(shù)讀取為空問(wèn)題、FormData表單提交MD5加密值不一致問(wèn)題2024-11-11maven打包插件的使用(maven-compiler-plugin、maven-dependency-plugin、m
本文主要介紹了maven打包插件的使用(maven-compiler-plugin、maven-dependency-plugin、maven-jar-plugin、maven-resources-plugin),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06