gpt4 book ai didi

javascript - 如何在客户端(vue.js)实现自动刷新?

转载 作者:行者123 更新时间:2023-11-28 17:06:26 26 4
gpt4 key购买 nike

注意:我已经分离了我的客户端(Vue.js)和服务器(DjangoRest)。我正在使用 JWT 来验证从客户端向服务器发出的每个请求。流动-客户端将用户凭据发送到服务器。如果凭据有效,服务器会发回刷新和访问 token 。客户端存储访问和刷新 token 。我已将刷新 token 有效期设置为 1 周,访问时间为 30 分钟。接下来,我想确保访问 token 在到期前 15 分钟自动刷新。为此,客户端存储的刷新 token 将发送到服务器,然后服务器发出新的访问 token 和刷新 token ,并将其发送回客户端。我如何在 Vuex 商店中实现这个?我是 Web 开发和 vue.js 的新手。如果有人可以提供一些代码或详细解释,那就太好了。

我已经在商店中实现了登录用户、注销用户、注册用户,它们工作正常。但我坚持自动刷新逻辑。我的猜测是客户端必须重复检查剩余的访问 token 到期时间。还剩大约 15 分钟时,我们必须初始化自动刷新功能。请帮我解释一下这个逻辑。

这是我的 Vueex 商店:

import Vue from 'vue'
import Vuex from 'vuex'
import axiosBase from './api/axios-base'
Vue.use(Vuex)

export default new Vuex.Store({
state: {
accessToken: '' || null,
refreshToken: '' || null
},
getters: {
loggedIn (state) {
return state.accessToken != null
}
},
mutations: {
loginUser (state) {
state.accessToken = localStorage.getItem('access_token')
state.refreshToken = localStorage.getItem('refresh_token')
},
destroyToken (state) {
state.accessToken = null
state.refreshToken = null
}
},
actions: {
registerUser (context, data) {
return new Promise((resolve, reject) => {
this.axios.post('/register', {
name: data.name,
email: data.email,
username: data.username,
password: data.password,
confirm: data.confirm
})
.then(response => {
resolve(response)
})
.catch(error => {
reject(error)
})
})
},
// fetch data from api whenever required.
backendAPI (context, data) {

},
logoutUser (context) {
if (context.getters.loggedIn) {
return new Promise((resolve, reject) => {
axiosBase.post('/api/token/logout/')
.then(response => {
localStorage.removeItem('access_token')
localStorage.removeItem('refresh_token')
context.commit('destroyToken')
})
.catch(error => {
context.commit('destroyToken')
resolve()
})
})
}
},
autoRefresh (context, credentials) {

},
loginUser (context, credentials) {
return new Promise((resolve, reject) => {
axiosBase.post('/api/token/', {
username: credentials.username,
password: credentials.password
})
.then(response => {
localStorage.setItem('access_token', response.data.access)
localStorage.setItem('refresh_token', response.data.refresh)
context.commit('loginUser')
resolve(response)
})
.catch(error => {
console.log(error)
reject(error)
})
})
}
}
})

提前谢谢您。

最佳答案

正如您所指出的,这在很大程度上是一个想法问题,因此有很多方法可以解决它。

在处理此类机制时,我要牢记的一件事是尽可能避免轮询。这是受该设计原则启发的解决方案。

JWT token 在非常特定的时间内有效。剩余的到期时间可以作为访问 token 的一部分轻松获得。您可以使用诸如jwt-decode之类的库解码访问 token 并提取过期时间。一旦确定了到期时间,您就有几个可用的选项:

  • 每次发出请求之前都检查 token 以了解是否需要刷新
  • 使用 setTimeout 在过期前 X 秒定期刷新

您的代码可以按如下方式实现:
注意:请将以下内容视为伪代码。我还没有测试过它是否有错误——语法或其他方面的错误。

export default new Vuex.Store({
...
actions: {
refreshTokens (context, credentials) {
// Do whatever you need to do to exchange refresh token for access token
...
// Finally, call autoRefresh to set up the new timeout
dispatch('autoRefresh', credentials)
},
autoRefresh (context, credentials) {
const { state, commit, dispatch } = context
const { accessToken } = state
const { exp } = jwt_decode(accessToken)
const now = Date.now() / 1000 // exp is represented in seconds since epoch
let timeUntilRefresh = exp - now
timeUntilRefresh -= (15 * 60) // Refresh 15 minutes before it expires
const refreshTask = setTimeout(() => dispatch('refreshTokens', credentials), timeUntilRefresh * 1000)
commit('refreshTask', refreshTask) // In case you want to cancel this task on logout
}
}
})

关于javascript - 如何在客户端(vue.js)实现自动刷新?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55747521/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com