vue加token,学习CSS行内样式

在这里插入图片描述

我才知道是需要给请求头加上token

王哥说

token 就是你登录的时候返回给你的数据

这个token 你需要登录后 存起来

然后 再开一个拦截器,每次访问请求的时候 都把这个token 加到请求头里面去

不开拦截器的话 你就要在代码中 手动给你要发送的请求的请求头中 加上token

然后我就去查如何 Vue 如何给请求带上请求头 | 如何带上token

可以在登陆的时候获取token,然后存起来,在拦截器里面判断是否有你的token,有就统一加上呗

每次跳页面, 都要获取新路由对应的html页面, 这时候可以用axios的http拦截每次路由跳转, 都先让后台验证一下token是否有效, 在http头添加token, 当后端接口返回 401 Unauthorized–未授权 ,让用户重新登录。

深入理解token

为什么用token?

Token 是在服务端产生的。如果前端使用用户名/密码向服务端请求认证,服务端认证成功,那么在服务端会返回 Token 给前端。前端可以在每次请求的时候带上 Token 证明自己的合法地位。如果这个 Token 在服务端持久化(比如存入数据库),那它就是一个永久的身份令牌。

需要为 Token 设置有效期吗?


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)

})

// 添加响应拦截器

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

文章到这里就结束了,如果觉得对你有帮助可以点个赞哦,如果有需要前端校招面试题PDF完整版的朋友可以点击这里即可免费获取,包括答案解析。

)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

文章到这里就结束了,如果觉得对你有帮助可以点个赞哦,如果有需要前端校招面试题PDF完整版的朋友可以点击这里即可免费获取,包括答案解析。

[外链图片转存中…(img-hRtO7BvS-1712225620866)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值