我必须在我的应用程序中进行大量 API 调用。我有大约 8 万亿次 Axios 调用。
所以我决定为 axious 创建一个辅助函数,并在每次我想要执行 HTTP 请求时将 URL 传递给它。
但是我收到一个错误,这是我的文件:
apiUtils.js:
const axios = require("axios")
const handleError = require('./apiHandleError')
const SERVER_DOMAIN = process.env.HOST;
const AuthorizationHeader = process.env.AUTH
const getHeaders = () => {
return {
headers: {
'Authorization': AuthorizationHeader
},
};
};
// HTTP GET Request - Returns Resolved or Rejected Promise
const getRequest = (url) => {
return new Promise((resolve, reject) => {
axios.get(`${SERVER_DOMAIN}${url}`, getHeaders())
.then(response => {
resolve(response)
})
.catch(error => {
reject(handleError(error))
});
});
};
module.exports = getRequest
//apihandleError.js - Common Error Handler Function
const handleError = (error) => {
let {
status,
message
} = error.response;
switch (status) {
case 401:
console.log(status)
break;
// do something when you're unauthenticated
case 403:
console.log(status)
// do something when you're unauthorized to access a resource
break;
case 404:
message = ({
status: `Couldn't reach Arena Gaming Server. Try again later`,
result: 404
})
// do something when the resource isnot found
break;
case 500:
console.log(status)
// do something when your server exploded
break;
default:
// handle normal errors with some alert or whatever
}
return message; // I like to get my error message back
}
module.exports = handleError
这就是我调用该函数的方式:
const userId = getRequest(`/api/reports/users/${userId}/general`)
.then(data => {
console.log(data);
// do something with User #5
})
.catch(errorMessage => {
console.log(errorMessage);
// the error has already been handled by handleError
// the message get's passed here
// do something like store it in redux, etc.
});
我收到错误消息结果是:状态:`无法到达 Arena 游戏服务器。稍后再试`,
结果:404
最佳答案
我认为您不需要将已经在另一个 promise 中返回 promise 的 axios.get
包装起来。你可以这样简化
const axios = require("axios");
const handleError = require("./apiHandleError");
const SERVER_DOMAIN = process.env.HOST;
const AuthorizationHeader = process.env.AUTH;
const getHeaders = () => {
return {
headers: {
Authorization: AuthorizationHeader
}
};
};
// HTTP GET Request - Returns Resolved or Rejected Promise
const getRequest = async url => {
try {
const response = await axios.get(`${SERVER_DOMAIN}${url}`, getHeaders());
return response;
} catch (err) {
return handleError(err);
}
};
用法可以像您正在使用的那样或async/await
希望这有帮助
关于javascript - NodeJS 使用 axios 可重用 HTTP 请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59647396/