项目中对于token的常用处理

1 存放

  • 项目中许多请求都是要token字符串的,所以把token字符串放到vuex中比较合适,一来方便获取,二来vuex是响应式的。
  • 当页面刷新时,vuex中的数据就会消失,所以需要对vuex做持久化处理,这里是把token字符串进行本地处理(localStorage)

2 发送请求时

许多请求都是要token字符串的,如果每次发送请求都写一遍(下图代码),比较麻烦

  headers: {
    Authorization: "Bearer token"
  }

这里使用axios提供的请求拦截器,也就是每个请求都需要先经过这个请求拦截器,然后才能发送给后端服务器,在 src/utils/request.js 中添加拦截器统一设置 token:

import axios from 'axios'
import store from '@/store'

const request = axios.create({
  baseURL: 'http://ttapi.research.itcast.cn/' // 接口的基准路径
})

// 请求拦截器
// Add a request interceptor
request.interceptors.request.use(function (config) {
  // Do something before request is sent
  // config :本次请求的配置对象
  // config 里面有一个属性:headers
  const { user } = store.state
  if (user && user.token) {
    config.headers.Authorization = `Bearer ${user.token}`
  }
  return config
}, function (error) {
  // Do something with request error
  return Promise.reject(error)
})

// 响应拦截器

export default request
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值