我的编程空间,编程开发者的网络收藏夹
学习永远不晚

解决axios:"timeoutof5000msexceeded"超时的问题

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

解决axios:"timeoutof5000msexceeded"超时的问题

axios:"timeout of 5000ms exceeded"超时

最近遇到一个问题,在我开机后,启动后台服务器登录程序时会报请求超时的问题。网上找了下解决方法,最后成功解决。

首先,我们要查看自己的请求地址是否正确,后端是否正常开启,数据库是否启动;若都正确无误,则继续往下看。

在看以下代码时,大家可以参考我的另一篇文章:vue开发中 axios 的封装

注:我使用的是 0.18.1 版本,0.19.0 版本似乎有问题,见:https://github.com/ly2011/blog/issues/159 中的评论。

具体代码如下: 

import axios from 'axios'
import { BASE_URL } from './http'
import router from '../router'
 
// create an axios instance
const service = axios.create({
  baseURL: BASE_URL, // url = base url + request url
  // withCredentials: true, // send cookies when cross-domain requests
  timeout: 5000 // request timeout
})
 
 
// 设置请求次数,请求的间隙
service.defaults.retry = 4;
service.defaults.retryDelay = 1000;
 
// request interceptor
service.interceptors.request.use(
  config => {
    // do something before request is sent
    return config
  },
  error => {
    // do something with request error
    // console.log(error) // for debug
    return Promise.reject(error)
  }
)
 
// response interceptor
service.interceptors.response.use(
  response => {
    const res = response.data
    return res
  },
  error => {
    if (error.response) {
      // console.log('err' + error) // for debug
      switch (error.response.status) {
        case 401:
          // console.log('err status' + error.response.status)
          router.push('/login')
          break
        case 404:
          break
        case 500:
          break
      }
      return Promise.reject(error)
    } else {
      // 处理超时的情况
      let config = error.config
      // If config does not exist or the retry option is not set, reject
      if(!config || !config.retry) return Promise.reject(error)
  
      // Set the variable for keeping track of the retry count
      config.__retryCount = config.__retryCount || 0
  
      // Check if we've maxed out the total number of retries
      if(config.__retryCount >= config.retry) {
        // Reject with the error
        return Promise.reject(error)
      }
  
      // Increase the retry count
      config.__retryCount += 1
  
      // Create new promise to handle exponential backoff
      let backoff = new Promise(function(resolve) {
        setTimeout(function() {
          resolve()
        }, config.retryDelay || 1)
      })
  
      // Return the promise in which recalls axios to retry the request
      return backoff.then(function() {
        return service(config)
      })
    }
 
  }
)
 
export default service

当请求超时后,axios 将重新发起请求,请求次数和间隙可以自己设定。

这里我创建了一个 axios 实例,所有 api 接口都通过这个实例进行请求。

如果你不想这样做,可以像下面这样写:

//在main.js设置全局的请求次数,请求的间隙
axios.defaults.retry = 4;
axios.defaults.retryDelay = 1000;
 
axios.interceptors.response.use(undefined, function axiosRetryInterceptor(err) {
    var config = err.config;
    // If config does not exist or the retry option is not set, reject
    if(!config || !config.retry) return Promise.reject(err);
 
    // Set the variable for keeping track of the retry count
    config.__retryCount = config.__retryCount || 0;
 
    // Check if we've maxed out the total number of retries
    if(config.__retryCount >= config.retry) {
        // Reject with the error
        return Promise.reject(err);
    }
 
    // Increase the retry count
    config.__retryCount += 1;
 
    // Create new promise to handle exponential backoff
    var backoff = new Promise(function(resolve) {
        setTimeout(function() {
            resolve();
        }, config.retryDelay || 1);
    });
 
    // Return the promise in which recalls axios to retry the request
    return backoff.then(function() {
        return axios(config);
    });
});

参考链接:https://github.com/axios/axios/issues/164

报错 Error: timeout of 5000ms exceeded

在确定后端代码没有问题,锁定前端

修改 \class="lazy" data-src\utils 目录下的 request.js

修改timeout属性值

有需要以后再来优化

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

解决axios:"timeoutof5000msexceeded"超时的问题

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

解决axios:"timeoutof5000msexceeded"超时的问题

这篇文章主要介绍了解决axios:"timeoutof5000msexceeded"超时的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

解决usageerror:linemagicfunction"%%time"notfound问题

这篇文章主要介绍了解决usageerror:linemagicfunction"%%time"notfound问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-04

关于tez-ui的"All DAGs"和"Hive Queries"页面信息为空的问题解决过程

近段时间发现公司的HDP大数据平台的tez-ui页面不能用了,页面显示为空,导致通过hive提交的sql不能方便地查找到Yarn上对应的applicationId,只能通过beeline的屏幕输出信息、hiveserver2的日志、yarn的日志等一步步去查找
关于tez-ui的"All DAGs"和"Hive Queries"页面信息为空的问题解决过程
2014-08-04

"Method Not Allowed"405问题分析以及解决方法

项目中在提交表单时,提示“HTTP405”错误——“MethodNotAllowed”这里显示的是,方法不被允许,下面这篇文章主要给大家介绍了关于"Method Not Allowed"405问题分析以及解决方法的相关资料,需要的朋友可以参考下
2022-11-13

解决Navicat Premium 连接 MySQL 8.0 报错"1251"的问题分析

人闲太久,努力一下就以为是在拼命。 一、问题 Navicat Premium 连接 MySQL 8.0 报错:1251 - Client does not support authentication protocol requested
2022-05-12

如何关闭WIN7右下角"解决PC问题"的提示?

最近有Win7系统用户反映,电脑开机后,WIN7 右下角 “解决PC问题”提示老是出现,而感觉又不经常用到它,怎么办?想要关掉它,又不知道怎么关。下面就来教教大家Win7系统要怎么关闭右下www.cppcns.com
2023-05-20

怎么解决Visual Studio无法打开源文件"stdio.h"问题

这篇文章主要介绍怎么解决Visual Studio无法打开源文件"stdio.h"问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!出现该问题是因为没有安装对应的Win10 SDK的原因,安装Visual Studi
2023-06-14

Python获取"3年前的今天"的日期时间问题

在Python中,如何获取" 3年前的今天"的datetime对象,本文通过实例代码给大家详细讲解,代码简单易懂对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
2023-01-11

"vSphere HA virtual machine failed to failover" error in vCenter Server问题怎么解决

这期内容当中小编将会给大家带来有关"vSphere HA virtual machine failed to failover" error in vCenter Server问题怎么解决,文章内容丰富且以专业的角度为大家分析和叙述,阅读完
2023-06-04

如何解决"您的服务器不支持mysql数据库"的问题

本篇内容主要讲解“如何解决"您的服务器不支持mysql数据库"的问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何解决"您的服务器不支持mysql数据库"的问题”吧!解决方法:在配置PHP时
2023-06-13

MySQL主从同步问题和延时从库的"闪回"是什么

本篇内容介绍了“MySQL主从同步问题和延时从库的"闪回"是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!背景:折腾MySQL-5.7.
2023-06-01

编程热搜

目录