vue加token,软件前端开发

24 阅读2分钟

token和localstorage的结合

axios.interceptors.request.use(function (config) {

let userInfo = localStorage.getItem('userInfo')

let token = ''

if (userInfo != undefined && userInfo.length > 10) {

userInfo = JSON.parse(userInfo)

if (userInfo.token) {

token = userInfo.token

}

}

//

// if (config.url.indexOf(url) === -1) {

// config.url = url + config.url /* 拼接完整请求路径 */

// }

// config.url = config.url.replace(////, '/')

config.withCredentials = true

config.headers = {

'token': token

}

return config

}, function (error) {

return Promise.reject(error)

})

axios.defaults.timeout = 30000 // 超时时间

axios.interceptors.response.use(function (response) {

// token 已过期,重定向到登录页面

if (response.data.status === 401) {

localStorage.clear()

router.replace('/')

}

return response

}, function (error) {

if (error.message.includes('timeout')) { // 判断请求异常信息中是否含有超时timeout字符串

return { data: { 'status': 601 } }

}

// Do something with response error

return Promise.reject(error)

})

方法1:

vuex + axios 做登录验证 并且保存登录状态


方法2:

在vue中如何获取token,并将token写进header

代码不一定,有几个报错的地方:

问:.vue文件如何引入store

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

login.vue

this.$axios({

method: 'post',

url: '/api/user/login',

data: params

}).then(res => {

console.log('登录成功')

console.log(res)

// 根据store中set_token方法将token保存至localStorage/sessionStorage中,data["Authentication-Token"],获取token的value值

this.$store.commit('set_token', data["Authentication-Token"])

if (store.state.token) {

this.$router.push('/person')

console.log(store.state.token)

} else {

this.$router.replace('/login')

}

})

store/index.js

import Vue from 'vue'

import Vuex from 'vuex'

Vue.use(Vuex)

export default new Vuex.Store({

state: {

token: ''

},

mutations: {

set_token (state, token) {

state.token = token

sessionStorage.token = token

},

del_token (state) {

state.token = ''

sessionStorage.removeItem('token')

}

},

actions: {

},

modules: {

}

})

main.js

import Vue from 'vue'

import './cube-ui'

import App from './App.vue'

import router from './router'

import store from './store'

import axios from 'axios'

import Cube from 'cube-ui'

Vue.use(Cube)

Vue.prototype.$axios = axios

Vue.config.productionTip = false

// 定义全局默认配置

axios.defaults.headers.common['Authentication-Token'] = store.state.token

// 添加请求拦截器

axios.interceptors.request.use(function (config) {

// 在发送请求之前做些什么

// 判断是否存在token,如果存在将每个页面header都添加token

if (store.state.token) {

config.headers.common['Authentication-Token'] = store.state.token

}

return config

}, function (error) {

// 对请求错误做些什么

return Promise.reject(error)

})

// 添加响应拦截器

axios.interceptors.response.use(function (response) {

// 对响应数据做点什么

return response

}, function (error) {

// 对响应错误做点什么

if (error.response) {

switch (error.response.status) {

case 401:

this.$store.commit('del_token')

router.replace({

path: '/login',

query: { redirect: router.currentRoute.fullPath }// 登录成功后跳入浏览的当前页面

})

}

}

return Promise.reject(error)

})

new Vue({

router,

store,

render: h => h(App)

}).$mount('#app')

router/index.js

import Vue from 'vue'

import VueRouter from 'vue-router'

import Login from '../views/Login.vue'

Vue 面试题

1.Vue 双向绑定原理 2.描述下 vue 从初始化页面–修改数据–刷新页面 UI 的过程? 3.你是如何理解 Vue 的响应式系统的? 4.虚拟 DOM 实现原理 5.既然 Vue 通过数据劫持可以精准探测数据变化,为什么还需要虚拟 DOM 进行 diff 检测差异? 6.Vue 中 key 值的作用? 7.Vue 的生命周期 8.Vue 组件间通信有哪些方式? 9.watch、methods 和 computed 的区别? 10.vue 中怎么重置 data? 11.组件中写 name 选项有什么作用? 12.vue-router 有哪些钩子函数? 13.route 和 router 的区别是什么? 14.说一下 Vue 和 React 的认识,做一个简单的对比 15.Vue 的 nextTick 的原理是什么? 16.Vuex 有哪几种属性? 17.vue 首屏加载优化 18.Vue 3.0 有没有过了解? 19.vue-cli 替我们做了哪些工作?

开源分享:docs.qq.com/doc/DSmRnRG…