[英]Express Request Aborted
我正在使用 Express.js 來實現我的后端。 我經常得到錯誤。 我不知道為什么。
我將源代碼放入 AWS Elastic Beanstalk 並設置 ELB。 如果此錯誤觸發次數過多,將導致所有用戶無法連接到服務器。 我總是重啟 Beanstalk 實例來解決這個問題。 但我不知道什么時候會觸發這個錯誤。 所以請幫我解決它。
非常感謝。
{
BadRequestError: request aborted
at IncomingMessage.onAborted (/var/app/current/node_modules/raw-body/index.js:231:10)
at IncomingMessage.emit (events.js:189:13)
at IncomingMessage.EventEmitter.emit (domain.js:441:20)
at abortIncoming (_http_server.js:449:9)
at socketOnClose (_http_server.js:442:3)
at Socket.emit (events.js:194:15)
at Socket.EventEmitter.emit (domain.js:441:20)
at TCP._handle.close (net.js:600:12)
message: 'request aborted',
code: 'ECONNABORTED',
expected: 18774,
length: 18774,
received: 0,
type: 'request.aborted',
expose: true,
statusCode: 400,
status: 400
}
app.use((req, res, next) => {
logger.info(`marker 1, ${req.header('Content-Type')}, ${req.header('Content-Length')}`)
next()
})
app.use(express.json({
type: 'application/json',
limit: '50mb',
strict: false,
verify: (req, res, buf, encoding) => {
logger.info(`marker 2, ${req.body.length}`)
}
}));
app.use(express.urlencoded({ extended: false }));
app.use(express.static(path.join(__dirname, 'public')));
// catch 404 and forward to error handler
app.use(function(e, req, res, next) {
// set locals, only providing error in development
logger.error(e);
const err = SQError.wrapError(e);
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
// render the error page
res.status(err.httpCode || 500);
var response = req.body.params ? req.body : {};
logger.error(err, req.app.get('env') === 'development' ? {method: req.body.method || ""} : {});
if(response.params)
response.params.error = err.toJson()
else
response = { error : err.toJson() }
res.json(response);
});
當請求在讀取正文完成之前被客戶端中止時,將發生此錯誤。 status 屬性設置為 400,type 屬性設置為“request.aborted”。 請把設置快遞代碼!
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.