当前位置: 首页 > news >正文

AJAX-项目优化(目录、基地址、token、请求拦截器)

目录管理

基地址存储

 在utils/request.js配置axios请求基地址

作用:提取公共前缀地址,配置后axios请求时都会baseURL+url

填写API的公共前缀后,将js文件导入到html文件中

<script src="../../utils/request.js"></script>

再使用axios请求接口的时候,只写API地址后半段

token

概念:访问权限的令牌,本质上是一串字符串

创建:正确登录后,由后端签发并返回

作用:判断是否有登录状态等,控制访问权限

注意:前端只能判断token有无,而后端才能判断token的有效性

如果很多接口都需要用header传递token,那么可以在请求拦截器里统一设置公共headers选项

官网:拦截器 | Axios中文文档 | Axios中文网

axios请求拦截器

发起请求之前,触发的配置函数,对请求参数进行额外配置

在utils/request.js中配置拦截器

// 添加请求拦截器
axios.interceptors.request.use(function (config) {// 在发送请求之前做些什么//统一携带token令牌字符串在请求头上const token = localStorage.getItem('token')token && (config.headers.Authorization = token)return config;}, function (error) {// 对请求错误做些什么return Promise.reject(error);});

axios响应拦截器

响应回到then/catch之前,触发的拦截函数,对响应结果统一处理

// 添加响应拦截器
axios.interceptors.response.use(function (response) {// 2xx 范围内的状态码都会触发该函数。// 对响应数据做点什么return response;}, function (error) {// 超出 2xx 范围的状态码都会触发该函数。// 对响应错误做点什么,例如:统一对401身份验证失败情况做出处理if(error?.response?.status === 401){alert('身份验证失败,请重新登录')}return Promise.reject(error);});

优化响应结果:可以观察返回信息的层级,把return response改为return response.data(或其他),这样获取到的返回信息都由response下的信息变为了response.data下的信息

http://www.lryc.cn/news/328961.html

相关文章:

  • SQLite中的动态内存分配(五)
  • 快速上手Spring Cloud 十一:微服务架构下的安全与权限管理
  • 如何简化多个 if 的判断结构
  • 发掘服务器硬件优势:怎样有效管理、维护、更新
  • SD卡备份和烧录ubuntu20.04镜像
  • 短视频账号矩阵系统/开发 -- -- -- 蒙太奇算法上线
  • Docker Stack(堆栈) 部署多服务集群,多服务编排
  • 全国青少年软件编程(Scratch)等级考试二级考试真题2023年12月——持续更新.....
  • python基础——异常捕获【try-except、else、finally】
  • JAVA面试大全之JVM和调优篇
  • 数据可视化-ECharts Html项目实战(8)
  • JavaSE:继承和多态(下篇)
  • springboot+mybatis项目集成p6spy输出格式化sql日志
  • yarn安装和使用及与npm的区别
  • 【3D-GS】Gaussian Splatting SLAM——基于3D Gaussian Splatting的全网最详细的解析
  • 推荐多样性 - 华为OD统一考试(C卷)
  • vue基础教程(4)——十分钟吃透vue路由router
  • 使用OpenSSL指令测试椭圆曲线签名算法ECDSA
  • ubuntu之搭建samba文件服务器
  • P10—P11:Java程序的编译和运行
  • 【Docker】Windows中打包dockerfile镜像导入到Linux
  • 数据结构之单链表实现(JAVA语言+C语言)
  • docker 安装Sentinel
  • 通过内网穿透、域名解析实现本地服务部署到公网的架构设计方案
  • 语音陪玩交友软件系统程序-app小程序H5三端源码交付,支持二开!
  • import关键字的使用
  • 江协STM32:点亮第一个LED灯和流水灯
  • 设计模式之建造者模式精讲
  • vue3源码解析——watch和watchEffect区别
  • 微服务(基础篇-006-Docker)