Files
yudao-ui-admin-vue3/src/utils/auth.ts

84 lines
2.3 KiB
TypeScript
Raw Normal View History

2026-02-27 09:47:06 +08:00
import { useCache, CACHE_KEY } from '@/hooks/web/useCache'
import { TokenType } from '@/api/login/types'
import { decrypt, encrypt } from '@/utils/jsencrypt'
// 登录态使用 sessionStorage每个浏览器标签页独立会话新标签打开同一 URL 需重新登录
const { wsCache: tokenCache } = useCache('sessionStorage')
// 租户、记住密码等仍用 localStorage便于跨标签保持
2026-02-27 09:47:06 +08:00
const { wsCache } = useCache()
const AccessTokenKey = 'ACCESS_TOKEN'
const RefreshTokenKey = 'REFRESH_TOKEN'
// 获取token
export const getAccessToken = () => {
// 此处与TokenKey相同此写法解决初始化时Cookies中不存在TokenKey报错
const accessToken = tokenCache.get(AccessTokenKey)
return accessToken ? accessToken : tokenCache.get('ACCESS_TOKEN')
2026-02-27 09:47:06 +08:00
}
// 刷新token
export const getRefreshToken = () => {
return tokenCache.get(RefreshTokenKey)
2026-02-27 09:47:06 +08:00
}
// 设置token
export const setToken = (token: TokenType) => {
tokenCache.set(RefreshTokenKey, token.refreshToken)
tokenCache.set(AccessTokenKey, token.accessToken)
2026-02-27 09:47:06 +08:00
}
// 删除token
export const removeToken = () => {
tokenCache.delete(AccessTokenKey)
tokenCache.delete(RefreshTokenKey)
2026-02-27 09:47:06 +08:00
}
/** 格式化tokenjwt格式 */
export const formatToken = (token: string): string => {
return 'Bearer ' + token
}
// ========== 账号相关 ==========
export type LoginFormType = {
tenantName: string
username: string
password: string
rememberMe: boolean
}
export const getLoginForm = () => {
const loginForm: LoginFormType = wsCache.get(CACHE_KEY.LoginForm)
if (loginForm) {
loginForm.password = decrypt(loginForm.password) as string
}
return loginForm
}
export const setLoginForm = (loginForm: LoginFormType) => {
loginForm.password = encrypt(loginForm.password) as string
wsCache.set(CACHE_KEY.LoginForm, loginForm, { exp: 30 * 24 * 60 * 60 })
}
export const removeLoginForm = () => {
wsCache.delete(CACHE_KEY.LoginForm)
}
// ========== 租户相关 ==========
export const getTenantId = () => {
return wsCache.get(CACHE_KEY.TenantId)
}
export const setTenantId = (tenantId: number) => {
wsCache.set(CACHE_KEY.TenantId, tenantId)
}
export const getVisitTenantId = () => {
return wsCache.get(CACHE_KEY.VisitTenantId)
}
export const setVisitTenantId = (visitTenantId: number) => {
wsCache.set(CACHE_KEY.VisitTenantId, visitTenantId)
}