- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的 previous question写得真的很糟糕(对此感到抱歉!)所以这次我会尽量把它做好。我正在使用 NodeJS 并编写了以下代码:
const car_reporter = {
// Some Code here (Removed to make it clear)
httpClient : null,
scriptReport: function(username, options) { // Some code here (Removed to make it clear)
},
APIReport: function(username, options) {
if (!(this.httpClient)) {
this.init();
}
try {
if ('car' in options) {
var reqConfig = {
method: 'post',
url: '/car',
headers: {
'content-type': 'application/json',
},
data: {
'carName': carName, // global
'username': username,
'car': options.car
}
};
this.httpClient(reqConfig).catch(function (error) {
throw new Error('Error while posting car\n' + error);
});
}
// OTHER CODE HERE - NOTICE ME :) (Removed to make it clear)
} catch (e) {
return e;
}
},
report: function (username, options) {
if (username === null) {
return new Error('Invalid username');
}
if (fs.existsSync(this.script_path)) {
return this.scriptReport(username, options);
} else {
return this.APIReport(username, options);
}
},
init: function() {
this.httpClient = axios.create({
baseURL: this.api_url
});
}
};
module.exports = car_reporter;
我这样调用它:
function report_car(user_id, car) {
var options = { car: car };
var result = car_reporter.report(user_id, options);
if (result instanceof Error) {
logger.error(result);
}
}
如果发布失败,我想在 APIReport
中抛出 Error
。但它说:UnhandledPromiseRejectionWarning: Unhandled promise rejection
。如果发布请求不起作用,这里处理错误并返回 Error
的正确方法是什么?我不能做 return this.httpClient(...
因为在那个请求之后还有其他代码。我可能需要添加 .then(...
但我该怎么做知道发帖失败了吗?
最佳答案
本版为评论提问。
如果你不想等待,你可以只删除 await
关键字,但是你不会收到 car_reporter.report
抛出的任何错误消息。
async function report_car(user_id, car) {
var options = { car: car };
try {
car_reporter.report(user_id, options);
} catch (error) {
logger.error(error);
}
}
你可以试试这个例子。
您将收到 UnhandledPromiseRejectionWarning
错误。
而你的 catch
block 将不会被执行。
function test () {
return new Promise((res, rej) => setTimeout(() => {
rej("not good")
}, 2000))
}
async function main() {
try {
test()
} catch (error) {
console.log("Get error");
console.log(error);
}
}
main()
在这种情况下,您可以在test()
后面添加.catch
。
function test () {
return new Promise((res, rej) => setTimeout(() => {
rej("not good")
}, 2000))
}
async function main() {
try {
test().catch((error) => {
console.log("Get error inside");
console.log(error)
})
} catch (error) {
console.log("Get error");
console.log(error);
}
console.log("done");
}
main()
执行上面的代码后,你会发现首先打印的是done
。然后 Get error inside
第二个被打印出来。我们假设您将在 console.log("done")
之后显示一些消息,但您不知道 test()
是否执行成功。 所以基本上,您不能在第一次执行时不等待就显示消息。
除非,您可以先向用户显示“正在处理”之类的消息。然后,告诉您的用户此 test()
是否成功。
回到你的代码。当您删除 await
时,您的 catch block 将无法正常工作。因此,您需要在 car_reporter.report
后面添加 .catch
。然后在 catch
block 中处理错误消息。您可以发送电子邮件告诉您的用户此报告已损坏。但是,我不确定这个程序在哪里运行。如果用express as api服务运行,轮询也是一种方法。
async function report_car(user_id, car) {
var options = {car: car};
try {
car_reporter.report(user_id, options).then((result) => {
// send email with this successful result
// tell your user this report is fine.
}).catch((error) => {
// send email with this error message
// tell your user this report is broken.
});
} catch (error) {
logger.error(error);
}
// told your user report is still processing.
}
我根据你的修改代码。
因为你在这里使用的是 axios,所以我将使用 async-await 来重构代码。
我将首先使用 async-await 来重构 report_car
函数中的用法。
async function report_car(user_id, car) {
var options = { car: car };
var result = await car_reporter.report(user_id, options);
if (result instanceof Error) {
logger.error(result);
}
}
然后我需要添加 try-catch 来避免 UnhandledPromiseRejectionWarning
。car_reporter.report
中的任何抛出错误都将在 catch block
中。
async function report_car(user_id, car) {
var options = { car: car };
try {
var result = await car_reporter.report(user_id, options);
} catch (error) {
logger.error(error);
}
}
接下来,如果username为null,则会出现错误信息。
把它改成throw
而不是return
,因为外面用了async-await。
如果您使用 return,它将被视为一个 resolved
promise。
因此,使用 throw
并使此错误发生在外部的 catch
block 上。
report: function (username, options) {
if (username === null) {
throw new Error('Invalid username');
}
if (fs.existsSync(this.script_path)) {
return this.scriptReport(username, options);
} else {
return this.APIReport(username, options);
}
},
并且在处理错误时,您应该使用 throw
而不是 return
。
然后你会在 report_car
函数的 catch
block 中得到错误。
APIReport: function (username, options) {
if (!(this.httpClient)) {
this.init();
}
try {
if ('car' in options) {
var reqConfig = {
method: 'post',
url: '/car',
headers: {
'content-type': 'application/json',
},
data: {
'carName': carName, // global
'username': username,
'car': options.car
}
};
const result = await this.httpClient(reqConfig)
// handle something with result if you need it
// other code here ...
}
} catch (e) {
// you could custom error message here, and throw to outside
// like `throw new Error("axios error")`
console.log(e)
throw new Error("axios error")
}
},
但是,如果上面例子中的这里的其他代码
有错误,会发生什么。
也许你调用了一个不存在的函数,它会抛出未定义的错误。
你的 catch block 也会捕获它。
此时,您将抛出 new Error("axios error")
,因为您自定义了错误消息。
那么,问题就来了。
如何区分这些错误或自定义?
您可以直接在您的 axios 中添加 catch
,然后自定义错误消息,如以下代码。
APIReport: function (username, options) {
if (!(this.httpClient)) {
this.init();
}
try {
if ('car' in options) {
var reqConfig = {
method: 'post',
url: '/car',
headers: {
'content-type': 'application/json',
},
data: {
'carName': carName, // global
'username': username,
'car': options.car
}
};
const result = await this.httpClient(reqConfig).catch((error) => {
throw new Error("APIReport axios error")
})
// handle something with result if you need it
// other code here ...
}
} catch (e) {
// here, you could throw other customized error message
// like, throw new Error("APIReport exception")
console.log(e)
throw e;
}
},
但是,如果您在 axios catch block 中抛出错误,node 将不会执行我在 other code here
中提到的以下代码。
如果你想让代码在axios出错时继续执行,你应该在axios catch block 中使用return
而不是throw
。
如果你不想让axios出错时代码不继续执行,你应该使用throw
。
这取决于您想要的情况。
整个代码如下所示。
const car_reporter = {
httpClient: null,
scriptReport: function (username, options) {},
APIReport: function (username, options) {
if (!(this.httpClient)) {
this.init();
}
try {
if ('car' in options) {
var reqConfig = {
method: 'post',
url: '/car',
headers: {
'content-type': 'application/json',
},
data: {
'carName': carName, // global
'username': username,
'car': options.car
}
};
const result = await this.httpClient(reqConfig).catch((error) => {
throw new Error("APIReport axios error")
})
// handle something with result if you need it
// other code here ...
}
} catch (e) {
// here, you could throw other customized error message
// like, throw new Error("APIReport exception")
console.log(e)
throw e;
}
},
report: function (username, options) {
if (username === null) {
throw new Error('Invalid username');
}
if (fs.existsSync(this.script_path)) {
return this.scriptReport(username, options);
} else {
return this.APIReport(username, options);
}
},
init: function () {
this.httpClient = axios.create({
baseURL: this.api_url
});
}
};
module.exports = car_reporter;
async function report_car(user_id, car) {
var options = { car: car };
try {
var result = await car_reporter.report(user_id, options);
} catch (error) {
logger.error(error);
}
}
希望对您有所帮助。
关于javascript - 在 NodeJS 中处理发布请求失败的正确方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65200949/
对于 Metal ,如果对主纹理进行 mipmap 处理,是否还需要对多采样纹理进行 mipmap 处理?我阅读了苹果文档,但没有得到任何相关信息。 最佳答案 Mipmapping 适用于您将从中
我正在使用的代码在后端 Groovy 代码中具有呈现 GSP(Groovy 服务器页面)的 Controller 。对于前端,我们使用 React-router v4 来处理路由。我遇到的问题是,通过
我们正在 build 一个巨大的网站。我们正在考虑是在服务器端(ASP .Net)还是在客户端进行 HTML 处理。 例如,我们有 HTML 文件,其作用类似于用于生成选项卡的模板。服务器端获取 HT
我正在尝试将图像加载到 void setup() 中的数组中,但是当我这样做时出现此错误:“类型不匹配,'processing .core.PImage' does not匹配“processing.
我正在尝试使用其私有(private)应用程序更新 Shopify 上的客户标签。我用 postman 尝试过,一切正常,但通过 AJAX,它带我成功回调而不是错误,但成功后我得到了身份验证链接,而不
如何更改我的 Processing appIconTest.exe 导出的默认图标在窗口中的应用程序? 默认一个: 最佳答案 经过一些研究,我能找到的最简单的解决方案是: 进入 ...\process
我在 Processing 中做了一个简单的小游戏,但需要一些帮助。我有一个 mp3,想将它添加到我的应用程序中,以便在后台循环运行。 这可能吗?非常感谢。 最佳答案 您可以使用声音库。处理已经自带
我有几个这样创建的按钮: 在 setup() PImage[] imgs1 = {loadImage("AREA1_1.png"),loadImage("AREA1_2.png"),loadImage
我正在尝试使用 Processing 创建一个多人游戏,但无法弄清楚如何将屏幕分成两个以显示玩家的不同情况? 就像在 c# 中一样,我们有Viewport leftViewport,rightView
我一直在尝试使用 Moore 邻域在处理过程中创建元胞自动机,到目前为止非常成功。我已经设法使基本系统正常工作,现在我希望通过添加不同的功能来使用它。现在,我检查细胞是否存活。如果是,我使用 fill
有没有办法用 JavaScript 代码检查资源使用情况?我可以检查脚本的 RAM 使用情况和 CPU 使用情况吗? 由于做某事有多种方法,我可能会使用不同的方法编写代码,并将其保存为两个不同的文件,
我想弄清楚如何处理这样的列表: [ [[4,6,7], [1,2,4,6]] , [[10,4,2,4], [1]] ] 这是一个整数列表的列表 我希望我的函数将此列表作为输入并返回列表中没有重复的整
有没有办法在不需要时处理 MethodChannel/EventChannel ?我问是因为我想为对象创建多个方法/事件 channel 。 例子: class Call { ... fields
我有一个关于在 Python3 中处理 ConnectionResetError 的问题。这通常发生在我使用 urllib.request.Request 函数时。我想知道如果我们遇到这样的错误是否可
我一直在努力解决这个问题几个小时,但无济于事。代码很简单,一个弹跳球(粒子)。将粒子的速度初始化为 (0, 0) 将使其保持上下弹跳。将粒子的初始化速度更改为 (0, 0.01) 或任何十进制浮点数都
我把自己弄得一团糟。 我想在我的系统中添加 python3.6 所以我决定在我的 Ubuntu 19.10 中卸载现有的。但是现在每次我想安装一些东西我都会得到这样的错误: dpkg: error w
我正在努力解决 Rpart 包中的 NA 功能。我得到了以下数据框(下面的代码) Outcome VarA VarB 1 1 1 0 2 1 1 1
我将 Java 与 JSF 一起使用,这是 Glassfish 3 容器。 在我的 Web 应用程序中,我试图实现一个文件(图像)管理系统。 我有一个 config.properties我从中读取上传
所以我一直在Processing工作几个星期以来,虽然我没有编程经验,但我已经转向更复杂的项目。我正在编写一个进化模拟器,它会产生具有随机属性的生物。 最终,我将添加复制,但现在这些生物只是在屏幕上漂
有人知道 Delphi 2009 对“with”的处理有什么不同吗? 我昨天解决了一个问题,只是将“with”解构为完整引用,如“with Datamodule、Dataset、MainForm”。
我是一名优秀的程序员,十分优秀!