【axios】-- axios 二次封装

这篇具有很好参考价值的文章主要介绍了【axios】-- axios 二次封装。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

基本封装部分

基本全局配置

如baseUrl,超出时间等

Token,密钥等

出于权限和安全考虑的密钥设置到请求头

响应的统一基本处理

主要针对于错误的情况做全局统一处理

封装的请求办法

把对接口的请求封装为一个方法

例子文章来源地址https://www.toymoban.com/news/detail-704474.html

// 配置全局的基础配置:baseUrl,timeout,header,responType,withCredentials
import axios from "axios"
import router from "@/router"

// 也可以把请求拦截器里的定义的东西提取出来,创建一个js文件(配置中心),在配置中心统一定义(后续好维护),通过import引入进来

// base64
import {Base64} from "js-base64"
// 后面的请求用request来发
let request = axios.creat({
    // 基础配置
    baseURL:'http://localhost:9090/',
    // timeout表示请求超过timeout时间没有响应就中断(单位为毫秒)
    timeout:30*1000,
    // responseType:"json" 规定后端返回的数据格式,默认值是json
    responseType:"json",
    headers:{
        // 看有没有什么特殊的header要加
    }
})

// 请求拦截器
request.interceptors.request.use((config)=>{
    // token密钥的设置
    let token = localStorage.getItem("token");
    let user = localStorage.getItem("user")
    // 如果有值,代表以及登录了。这块我还没有详细区分这两个,都先判断,等研究这个的时候再来重写
    if (token || user){
        // 记得输出一下token和保存的user,下面的赋值,取决于user 的输出
        config.headers.token = token
    }

    // 密钥-secretId + 特殊算法(防止别人把token复制出来伪造请求)jwt记得研究一下
    let secretId = "hello";
    let secret = Base64.encode(secretId+new Date().toString()); //这里用的是后面加上时间戳,这个需要后端也加,然后进行比对就知道是不是客户端发送的了。记得要进行加密
    config.headers.secret = secret;
    return config
},error =>{
    // 请求出错了
    return Promise.reject(new Error(error))
})

// 响应拦截器
request.interceptors.response.use((res)=>{
    // 响应的统一处理(一般是来判断后端返回的状态码)
    // 只要发送成功,默认200
    const status = res.data.code || 200
    // 如果没有附带消息,默认"未知错误"
    const message = res.data.msg || "未知错误"
    if(status === 401){
        // 没权限,重新登录
        router.push("/login")
    }
},error =>{
    // 组件库的提示,$waring
    return Promise.reject(new Error(error))
})

export default request

到了这里,关于【axios】-- axios 二次封装的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • axios二次封装

    目录 第一章、前言 1.1 axios是什么 1.2 axios二次封装的原因 1.3 axios的特性 第二章、axios的二次封装 2.1 axios安装 2.2 axios封装一般步骤 2.3 axios封装常用的配置项 2.4 使用封装的axios 是一个基于Promise 用于浏览器和 nodejs 的 HTTP 客户端,简单的理解就是ajax的封装 在使用Vue.js框架开发

    2024年02月07日
    浏览(62)
  • 关于axios的二次封装

    @1 第一步 我们一般都会先导入axios         import axios from ‘axios’ @2 第二步 创建axios的实例 可以同时创建多个实例 每个实例配置不同         const http = axios.create( {                  // 这里面可以做一些基础的配置 比如基础路径 ,axios 请求超时的时间            

    2024年02月03日
    浏览(55)
  • axios介绍以及对axios进行二次封装

    目录 一、axios基础 1、什么是axios? 2、axios的安装 3、axios常用配置项 4、axios和ajax的区别  二、使用axios发送请求 1、 发送get无参请求 2、 发送get有参请求 3、 发送post无参请求 4、 发送post有参请求 4.1 发送json格式的数据: 4.2 发送表单格式的数据: 三、 then、catch、finally 四、

    2023年04月14日
    浏览(47)
  • 前端开发中的ajax请求、axios封装

    目录 浏览器http请求 同步 js标签跨域、url 异步ajax、websock协议 ajax是异步的技术术语,最早的api是xhr(XMLHttpRequest) fetch es6 api axios 封装axios(无论用requst还是axios请求都会生效) src/utils/request.ts请求/响应拦截器封装 ts post请求request.post(url)和 通用请求request({url,method:\\\'post\\\'})对象

    2024年02月11日
    浏览(51)
  • Axios的二次封装(简单易懂)

    是一个基于Promise 用于浏览器和 nodejs 的 HTTP 客户端 简单的理解就是ajax的封装 在使用Vue.js框架开发前端项目时 会经常发送ajax请求服务端接口 在开发过程中 需要对axios进一步封装 方便在项目中的使用 从浏览器中创建 XMLHttpRequest 从 node.js 发出 http 请求 支持 Promise API 拦截请求

    2023年04月09日
    浏览(113)
  • Vue——axios的二次封装

    在 Vue 中,发送请求一般在 created 钩子中,当然放在 mounted 钩子中也没问题。 以下请求的前提都是安装了 axios,并且 import axios from \\\'axios\\\' 成功导入 Axios官网链接 get 请求传参,在地址里面通过 ?xxx=123 的形式 post 请求传参,在第二个参数里面传递 请求配置里面可以设置很多属性

    2024年02月11日
    浏览(51)
  • Vue电商项目--axios二次封装

    刚刚经过postman工具测试,发现接口果然发生了改变。 新的接口为 http://gmall-h5-api.atguigu.cn   如果服务器返回的数据code字段200,代表服务器返回数据成功 整个项目,接口前缀都有/api字样 XmlHttpRequest,fetch,JQ,Axios这些都是很优秀的网络请求库 为什么需要进行二次封装axios? 请

    2024年02月01日
    浏览(51)
  • axios二次封装(详细+跨域问题)

    一,为什么要对axios进行二次封装? 答:主要是要用到请求拦截器和响应拦截器; 请求拦截器 : 可以在发请求之前可以处理一些业务 响应拦截器 : 当服务器数据返回以后,可以处理一些事情 二,axios的二次封装 2.1 安装axios 在当前的项目路径下安装 安装成功 2.2 通常情况下

    2024年02月06日
    浏览(42)
  • Vue项目中axios的二次封装

    Vue 项目使用过程中一般会对 axios 进行二次封装, 以期在合适的时机处理一些全局的需求, 比如常见的 请求拦截器 和 响应拦截器. 接下来简单聊聊具体的操作步骤. 执行以下指令: 在 src 文件夹下创建 api 文件夹, 并创建 index.js、axios.js 和 users.js 文件. index.js 文件的作用的将当前

    2024年01月19日
    浏览(90)
  • vue对axios进行二次封装

            在Vue中,对Axios进行二次封装可以提高代码的可重用性和可维护性。通过封装,我们可以将请求的配置、错误处理和拦截器等逻辑集中到一个地方,方便后续的修改和扩展。此外,封装Axios还可以简化代码,减少重复的请求配置,提高开发效率。因此,对Axios进行二

    2024年01月21日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包