好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

解决axios:"timeout of 5000ms exc

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

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

修改 \src\utils 目录下的 request.js

修改timeout属性值

有需要以后再来优化

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

查看更多关于解决axios:"timeout of 5000ms exc的详细内容...

  阅读:63次