vue 使用用户名和密码成功登录后,获取返回结果header中的token信息,存储到cookie中,发送请求时从cookie中获取token
auth.js
import Cookies from 'js-cookie'
const TokenKey = 'vue_admin_template_token'
export function getToken() {
return Cookies.get(TokenKey)
}
export function setToken(token) {
return Cookies.set(TokenKey, token)
}
export function removeToken() {
return Cookies.remove(TokenKey)
}
request.js ,编写request和response拦截器,获取header中的Authorization信息对token进行更新,request拦截器对发送请求时在header中加入Authorization 的token信息。
import axios from 'axios'
import { Message, MessageBox } from 'element-ui'
import store from '../store'
import { setToken, getToken, removeToken } from '@/utils/auth'
// 创建axios实例
const service = axios.create({
/* baseURL: process.env.BASE_API, */ // api 的 base_url
timeout: 10000 // 请求超时时间
})
// request拦截器
service.interceptors.request.use(
config => {
if (store.getters.token) {
// 让每个请求携带自定义token 请根据实际情况自行修改
config.headers['Authorization'] = getToken()
}
return config
},
error => {
// Do something with request error
console.log(error) // for debug
Promise.reject(error)
}
)
// response 拦截器
service.interceptors.response.use(
response => {
// 刷新Token
var accessToken = response.headers['authorization']
if (accessToken) {
console.log('RefreshToken:' + accessToken)
removeToken()
setToken(accessToken)
}
/**
* code为非20000是抛错 可结合自己业务进行修改
*/
const res = response.data
if (res.code !== 200) {
Message({
message: res.msg,
type: 'error',
duration: 5 * 1000
})
// 50008:非法的token; 50012:其他客户端登录了; 50014:Token 过期了;
if (res.code === 50008 || res.code === 50012 || res.code === 50014) {
MessageBox.confirm(
'你已被登出,可以取消继续留在该页面,或者重新登录',
'确定登出',
{
confirmButtonText: '重新登录',
cancelButtonText: '取消',
type: 'warning'
}
).then(() => {
store.dispatch('FedLogOut').then(() => {
location.reload() // 为了重新实例化vue-router对象 避免bug
})
})
}
return Promise.reject('error')
} else {
return response.data
}
},
error => {
console.log('err' + error) // for debug
console.log(error.response.data)
let msg = error.response.data.msg
if (error.response.data.code === 500) {
msg = '服务器异常'
}
Message({
message: msg,
type: 'error',
duration: 5 * 1000
})
return Promise.reject(error)
}
)
export default service
来源:CSDN
作者:佩奇的胖爸爸
链接:https://blog.csdn.net/qq_39508627/article/details/104493033