Vue项目实战中token和axios的二次封装使用,一起来写出优雅的项目结构

前言

token通常在管理系统中用来进行身份和权限验证,大家应该都不陌生,这篇文章教大家对token和axios进行封装,保持项目结构良好的可读性,对token比较陌生的同学,那就赶紧学起来吧~

什么是token

token是对用户进行登录验证的一串密钥,它由后端生成,一般前端进行登录验证通过后就会得到后端返回过来的token,后期的一些操作请求也需要携带token来保证接口安全

token身份验证的过程

  1. 前端发送登录请求
  2. 请求成功,拿到token,存入本地localstorage中
  3. 发送请求携带token,后端验证token返回结果
  4. 退出登录,销毁token

token 的封装

上面叙述了token的验证过程,那么对于token我们需要先把他存储到本地,然后每次请求携带token,最后退出登录需要销毁token。所以需要三个方法分别是:存储,拿到,销毁
对于这三种方法,为了方便使用,我们对其进行封装
一般建立utils文件夹存放一些工具方法,在里面新建token.js文件

export function setToken(tokenKey, token) {
    // 将token存入localStorage
    return localStorage.setItem(tokenKey, token)
}

export function getToken(tokenKey) {
   	//拿到localStorage中的token
    
  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论
对于Vue2项目的二次封装axios,可以按照以下步骤进行: 1. 安装axios:在项目根目录运行以下命令安装axios: ``` npm install axios ``` 2. 创建封装文件:在项目的src目录下创建一个api文件夹,并在该文件夹下创建一个request.js文件(或者其他你喜欢的文件名)。 3. 在request.js文件引入axiosVue: ```javascript import axios from 'axios' import Vue from 'vue' ``` 4. 创建一个axios实例,并设置一些默认配置: ```javascript const instance = axios.create({ baseURL: process.env.BASE_URL, // 设置接口根路径,可以根据需要进行配置 timeout: 10000, // 设置请求超时时间,单位为毫秒 headers: { 'Content-Type': 'application/json' // 设置请求头部类型 } }) ``` 5. 添加请求拦截器,在请求发送前做一些处理,例如添加Token等: ```javascript instance.interceptors.request.use( config => { // 在请求发送前做一些处理 const token = localStorage.getItem('token') if (token) { config.headers.Authorization = `Bearer ${token}` } return config }, error => { // 处理请求错误 console.error(error) return Promise.reject(error) } ) ``` 6. 添加响应拦截器,对返回的数据进行处理: ```javascript instance.interceptors.response.use( response => { // 对返回的数据进行处理 return response.data }, error => { // 处理响应错误 console.error(error) return Promise.reject(error) } ) ``` 7. 将axios实例挂载到Vue原型上,这样在组件可以通过this.$http来访问axios实例: ```javascript Vue.prototype.$http = instance ``` 8. 在组件使用封装axios: ```javascript export default { methods: { fetchData() { this.$http.get('/api/data') .then(response => { // 处理返回的数据 }) .catch(error => { // 处理请求错误 }) } } } ``` 这样就完成了Vue2项目axios的二次封装。你可以根据项目需求自定义一些其他的配置和处理逻辑。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Beiyux

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值