错误中间件不工作在后端与express和云功能



我正试图用错误中间件快速处理错误。这是我的索引:

const functions = require("firebase-functions");
const express = require("express");
const cors = require("cors");
require("dotenv").config();
const methodOverride = require('method-override')
const {logErrors, errorHandler,boomErrorHandler, error404Handler } = require("./src/middlewares/error.handler")
//modulos personalizados
const { productsRoutes } = require("./src/products/products.routes");
const userRoutes = require("./src/users/user.routes");
const UserServices = require("./src/users/user.services")
//nombre
const userService = new UserServices
const app = express();
app.use(express.urlencoded({ extended: true }));
app.use(express.json());
app.use(cors({ origin: true }));
app.use(methodOverride());
app.use(logErrors);
app.use(boomErrorHandler);
app.use(errorHandler);
// app.use(error404Handler);

exports.setCustomerClaim = functions.auth
.user()
.onCreate(userService.customerClaimServ)
productsRoutes(app);
exports.api = functions.https.onRequest(app);

如你所见,我有logErrors中间件。

这是我的简单控制器抛出的东西很好,但当我做一个next()catch()它不会进入错误中间件。

this is my controller:

async function getAll(req, res, next) {
try {
const products = await productServices.getAllSer();
console.log("Aca esta tu error");
res.json(products);
} catch (error) {
next();
}
}

这是我的中间件:

/* eslint-disable @typescript-eslint/no-var-requires */
const boom = require("@hapi/boom");
function logErrors(err, req, res, next) {
console.error(err);
next(err);
}
function errorHandler(err, req, res, next) {
if (err) {
res.status(409).json({
message: err.message,
stack: err.stack,
});
} else {
next(err);
}
}
function boomErrorHandler(err, req, res, next) {
if (err.isBoom) {
const {output} = err;
res.status(output.statusCode).json(output.payload);
}
next(err);
}
function error404Handler (req, res) {
res.status(404)
res.send ({
message: boom.notFound('el recurso que busca no existe')
})
}
module.exports= {
logErrors,
errorHandler,
boomErrorHandler,
error404Handler
};

问题是,它没有进入错误中间件,因为next()之前的任何内容都工作正常。

我将感激任何帮助。提前感谢!

你的问题是在控制器,使用这样的return next(error);:

async function getAll(req, res, next) {
try {
const products = await productServices.getAllSer();
console.log("Aca esta tu error");
res.json(products);
} catch (error) {
return next(error);
}
}

最新更新