第70讲axios后端请求工具类封装

axios工具类封装:

bash 复制代码
// 引入axios
import axios from 'axios';

// 创建axios实例
const httpService = axios.create({
  // url前缀-'http:xxx.xxx'
  // baseURL: process.env.BASE_API, // 需自定义
  baseURL:'http://localhost:80/',
  // 请求超时时间
  timeout: 3000 // 需自定义
});

//添加请求和响应拦截器
// 添加请求拦截器
httpService.interceptors.request.use(function (config) {
  // 在发送请求之前做些什么
  config.headers.token=window.sessionStorage.getItem('token');
  return config;
}, function (error) {
  // 对请求错误做些什么
  return Promise.reject(error);
});

// 添加响应拦截器
httpService.interceptors.response.use(function (response) {
  // 对响应数据做点什么
  return response;
}, function (error) {
  // 对响应错误做点什么
  return Promise.reject(error);
});

/*网络请求部分*/

/*
 *  get请求
 *  url:请求地址
 *  params:参数
 * */
export function get(url, params = {}) {
  return new Promise((resolve, reject) => {
    httpService({
      url: url,
      method: 'get',
      params: params
    }).then(response => {
      resolve(response);
    }).catch(error => {
      reject(error);
    });
  });
}

/*
 *  post请求
 *  url:请求地址
 *  params:参数
 * */
export function post(url, params = {}) {
  return new Promise((resolve, reject) => {
    httpService({
      url: url,
      method: 'post',
      data: params
    }).then(response => {
      console.log(response)
      resolve(response);
    }).catch(error => {
      console.log(error)
      reject(error);
    });
  });
}

/*
 *  文件上传
 *  url:请求地址
 *  params:参数
 * */
export function fileUpload(url, params = {}) {
  return new Promise((resolve, reject) => {
    httpService({
      url: url,
      method: 'post',
      data: params,
      headers: { 'Content-Type': 'multipart/form-data' }
    }).then(response => {
      resolve(response);
    }).catch(error => {
      reject(error);
    });
  });
}

export default {
  get,
  post,
  fileUpload
}

配置@作为根目录

vue.config.js里面配置:

bash 复制代码
  configureWebpack:{
      resolve:{
          alias:{
              '@':resolve('src')
          }
      }
  },

导入axios工具类;

bash 复制代码
import axiosUtil from '@/util/axios'

改下:

bash 复制代码
try{
        let result=await axiosUtil.post("adminLogin",form.value);
        let data=result.data;
        if(data.code==0){
          ElMessage.success("登录成功");
          window.sessionStorage.setItem("token",data.token);
        }else{
          ElMessage.error(data.msg);
        }
      }catch(err){
        console.log("error:"+err);
        ElMessage.error("系统运行出错,请联系管理员");
      }
相关推荐
oil欧哟6 分钟前
🙂我用 TS 实现了一个 OpenAPI 转 MCP 工具,让 AI 工具调用更简单!
前端·人工智能·mcp
JohnYan11 分钟前
Bun技术评估 - 10 Testing
javascript·后端·bun
YYsuni15 分钟前
Google Translate 导致的 React 页面崩溃
前端
会一丢丢蝶泳的咻狗15 分钟前
uni-app安卓端强制更新apk包
android·前端·uni-app
逝水如流年轻往返染尘16 分钟前
CSS基础学习1
前端·css·学习
Hilaku17 分钟前
我踩爆了 CSS Module 的所有坑,别再被骗了
前端·css·react.js
北城笑笑19 分钟前
Server 11 ,⭐通过脚本在全新 Ubuntu 系统中安装 Nginx 环境,安装到指定目录( 脚本安装Nginx )
linux·运维·前端·nginx·ubuntu
小赵学鸿蒙21 分钟前
如何使用第三方库中的@pura/harmony-utils(V1.3.3)申请授权工具类一
前端
断竿散人22 分钟前
CSS选择器与伪类:精准定位元素的终极指南!
前端
憨憨是条狗22 分钟前
在 Vue + Vant + ArcGIS 环境中设置 GraphicsLayer 的标题
前端