在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