在vue中,可以用**Storage(sessionStorage,localStorage)**来存储token,也可以用vuex来存储(但要考虑页面刷新数据消失问题,可以在vuex用Storage),
下面介绍用localStorage来存储:
在登录请求成功后,会返回一个token值,用loaclStorage保存
localStorage.setItem('token',res.data.token)
在main.js中设置全局请求头和响应回来的判断
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
//设置axios请求头加入token
Axios.interceptors.request.use(config => {
if (config.push === '/' ) {
} else {
if (localStorage.getItem( 'token' )) {
//在请求头加入token,名字要和后端接收请求头的token名字一样
config.headers.token=localStorage.getItem( 'token' );
}
}
return config;
},
error => {
return Promise.reject(error);
});
//=============================
//响应回来token是否过期
Axios.interceptors.response.use(response => {
console.log( '响应回来:' +response.data.code)
//和后端token失效返回码约定403
if (response.data.code == 403) {
// 引用elementui message提示框
ElementUI.Message({
message: '身份已失效' ,
type: 'err'
});
//清除token
localStorage.removeItem( 'token ' );
//跳转
router.push({name: 'login' });
} else {
return response
}
},
error => {
return Promise.reject(error);
})
|
在router中的index设置全局守卫来判断是否存在token,不存在就返回登录页
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
router.beforeEach((to, from, next) => {
//to到哪儿 from从哪儿离开 next跳转 为空就是放行
if (to.path === '/' ) {
//如果跳转为登录,就放行
next();
} else {
//取出localStorage判断
let token = localStorage.getItem( 'token ' );
if (token == null || token === '' ) {
console.log( '请先登录' )
next({name: 'login' });
} else {
next();
}
}});
|
补充知识:Vue获取并存储服务器返回的AuthorizationToken信息并给每次请求添加上token
由于后台是用jwt的token进行身份权限验证,后台在登录后把token添加响应头里,所以前台需要把这个token存放起来,并给每次请求的请求头添加上token,服务器才能获取token进行身份认证。
前台使用vue项目:
loging.vue(登录组件)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
{
submitForm(formName) {
this .$axios
.post( '/api/admin/login' , {
userName: this .ruleForm.userName,
password: this .ruleForm.password
})
.then(successResponse => {
this .responseResult = JSON.stringify(successResponse.data)
this .msg = JSON.stringify(successResponse.data.msg)
if (successResponse.data.code === 200) {
this .msg= '' ;
localStorage.setItem( 'userName' , this .ruleForm.userName);
//获取并存储服务器返回的AuthorizationToken信息
var authorization=successResponse.headers[ 'authorization' ];
localStorage.setItem( 'authorization' ,authorization);
//登录成功跳转页面
this .$router.push( '/dashboard' );
}
})
. catch (failResponse => {})
}
}
|
main.js(全局配置js):
1
2
3
4
5
6
7
8
|
//自动给同一个vue项目的所有请求添加请求头
axios.interceptors.request.use( function (config) {
let token = localStorage.getItem( 'authorization' );
if (token) {
config.headers[ 'Authorization' ] = token;
}
return config;
})
|
这里还需要考虑token过期失效的问题,博主将会在后续另写博客补充。
以上这篇Vue中登录验证成功后保存token,并每次请求携带并验证token操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/qq_40788898/article/details/106915940