错误处理程序中间件不处理错误



开始使用此npm包以避免所有try-catches块和promise。它感觉错误处理程序一直在"休眠"。也许有人知道我在这件事上做错了什么?如果我用try-catch包装异步函数,它会用代码23505捕获错误——所以基本上,处理程序应该解决这个问题,但它没有。此外,错误:未处理的PromiseRejectionWarning:未处理的promise rejection。此错误源于在没有catch块的异步函数内部抛出,或拒绝未使用.catch((处理的promise。若要在未处理的promet拒绝时终止节点进程。。是的,我明白我需要解决这个错误,但这就是我使用中间件+包来避免所有错误的原因。然后.catch

在我的主文件-顶部的app.js中,我需要这个包:

require("express-async-errors");

在这里,我调用失败的函数(我现在是故意这么做的(

const {hashPassword} = require("../utils/bcryptUtils");
const {registerUserDao} = require("../dao/usersDao");
const registerService = async (requestUser) => {
const registrationPayload = {
email: requestUser.email.toLowerCase(),
password: await hashPassword(requestUser.password),
phone_number: requestUser.phone_number,
first_name: requestUser.first_name.charAt(0).toUpperCase() + requestUser.first_name.slice(1),
last_name: requestUser.last_name.charAt(0).toUpperCase() + requestUser.last_name.slice(1),
};
// If I wrap this await function in try catch I can handle the error here
await registerUserDao(registrationPayload);
};
module.exports = {
registerService
};

和道:

const database = require("../database/knex");
const registerUserDao = async (userPayload) => {
return database("users").insert(userPayload).returning("*");
};
module.exports = {
registerUserDao
};

错误处理程序中间件:

const {StatusCodes} = require("http-status-codes");
const errorHandlerMiddleware = (err, req, res, next) => {
console.log(`error activated! ` + err);
let customError = {
statusCode: err.statusCode || StatusCodes.INTERNAL_SERVER_ERROR,
message: err.message || "Something went wrong.. Please try again later."
};
if (err.code === "23505") {
customError.statusCode = 409;
customError.message = "Duplicate error. Client with provided data already exsists";
}
return res.status(customError.statusCode).json({message: customError.message});
};
module.exports = errorHandlerMiddleware;

当然,我把它添加到了我的路线的最后:

// middlewares
const errorHandlerMiddleware = require("./middlewares/errorHandlerMiddleware");
// routes
app.use("/api/v1/auth", authRouter);
app.use(errorHandlerMiddleware);

在这里我呼叫registerService

const {registerService} = require("../services/authServices");
const {StatusCodes} = require("http-status-codes");
// Yup I see the issue now! Been missing await before
const registerController = async (req, res) => {
const response = registerService(req.body);
res.status(StatusCodes.CREATED).json({response});
};

module.exports = {
registerController
};

似乎中间件函数没有返回(最终被拒绝(承诺,所以包的代码永远看不到它。

在对registerService(或调用堆栈中更高的位置(的调用中,很可能缺少一个await关键字。

最新更新