调用中间件进行错误处理但不处理响应

时间:2019-05-09 01:02:19

标签: javascript node.js express middleware

我试图通过返回json处理错误,但是我的错误处理程序(在调用时,登录控制台)不会返回我试图返回的内容。这是处理程序:

const handleError = function(err, req, res, next) {
    console.log(err);
    res.setHeader('Content-Type', 'application/json');
    res.status(500);
    res.send(JSON.stringify(error));
}

但是我得到了一个渲染函数,该函数转换为以下以用户身份返回给我的内容:

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8">
        <title>Error</title>
    </head>
    <body>
        <pre>Invalid token with reason JsonWebTokenError: jwt malformed</pre>
    </body>
</html>

因此它仍然会记录错误,但是除非我在实际函数中返回错误,否则它不会按预期返回,又名以下函数确实会返回书面的json错误:

const view = function(req,  res, model, settings = {}, callback)  {
    let { params } = req;
    let { _id } = params;
    let { select, limit, sort } = settings;
    let query = model.findById(_id);
    if (select) query.select(select);
    if (sort) query.sort(sort);
    if (limit) query.limit(limit);
    query.exec(function(err, data) {
        if(callback) {
            callback(err,data);
        }else{
            if (err) return res.status(400).json({ 'Error': err.message });
            if (!data) return res.status(404).json({ 'Error': `No document with id ${_id} found` });
            return res.status(200).json(data);
        }
    });
}

这是我注册中间件的方式

let app = express();
app.server = http.createServer(app);

// logger
app.use(morgan('dev'));

// 3rd party middleware
app.use(cors({
    exposedHeaders: config.corsHeaders
}));

// Custom error handling 
app.use(api.handleError);

//Set body as json as recieved
app.use(bodyParser.json({
    limit : config.bodyLimit
}));

2 个答案:

答案 0 :(得分:0)

当我阅读有关错误处理的express documentation时,在我看来您应该{em> 到throw new Error()(或致电next(),具体取决于处理程序的同步/异步性质),以使错误处理程序正常工作。

在上面的代码中,我看到你return res.status().json(),我认为这是不一样的。

您已经指出unless I return an error in my actual function, it won't return as intended-听起来您已经知道发生了什么。

您还提到handleError应该返回JSON-为什么不更改它:

res.status(500);
res.send(JSON.stringify(error));

...到...

res.status(500).json(error)

那应该给你你所需要的。

答案 1 :(得分:0)

尝试在路径下添加错误处理程序中间件。示例:

app.get('/', indexHandler)
//call next(err) in indexHandler if there is an error
app.use(errorHandler)