Express 快速异步/等待错误处理

Express 快速异步/等待错误处理,express,error-handling,promise,async-await,Express,Error Handling,Promise,Async Await,} 每个快速异步路由都经过包装,以捕获路由处理程序函数中的任何拒绝或抛出错误。无论何时出现这样的拒绝或错误-wrap都会被很好地调用,并且我能够看到出现错误的打印>> 但是,我无法将该错误传递到错误处理程序中间件,我打算在该中间件中发送带有JSON错误的400 在上面的场景中,我如何解决这个问题???对不起,我无法分离出一段示例代码来轻松演示这个错误。我使用的是mysql、express——混合了promises和ES6 下面是我遇到的一个问题及其解决方案的示例 问题是:我在初始化路由之前添加了

}

每个快速异步路由都经过包装,以捕获路由处理程序函数中的任何拒绝或抛出错误。无论何时出现这样的拒绝或错误-wrap都会被很好地调用,并且我能够看到出现错误的打印>>

但是,我无法将该错误传递到错误处理程序中间件,我打算在该中间件中发送带有JSON错误的400


在上面的场景中,我如何解决这个问题???

对不起,我无法分离出一段示例代码来轻松演示这个错误。我使用的是mysql、express——混合了promises和ES6

下面是我遇到的一个问题及其解决方案的示例

问题是:我在初始化路由之前添加了错误处理中间件。最后添加错误中间件解决了这个问题


很抱歉,我无法分离出一段示例代码来轻松演示该错误。我使用的是mysql、express——混合了promises和ES6

下面是我遇到的一个问题及其解决方案的示例

问题是:我在初始化路由之前添加了错误处理中间件。最后添加错误中间件解决了这个问题


使用您的代码,使用一个总是拒绝的伪urlhandler,我无法复制您描述的问题res.status400.json{error:err};是否使用您的代码为我调用,使用一个始终拒绝的伪urlhandler,我无法复制您描述的问题res.status400.json{error:err};有人为我打电话吗
class XYZ {

  constructor(app) {

    // app is express object
    this.app = app;

    this.app.route('/api/url')
      .get(this.wrap(this.urlhandler.bind(this)));

    // to send error as json -> this never gets invoked ??
    this.app.use((err, req, res, next) => {
      res.status(400).json({error: err});
      next(err);
    });

  }

  // wraps each async route function to handle rejection and throw errors
  wrap(fn) {
    return function (req, res, next) {
      Promise.resolve(fn(req, res, next)).catch(function (err) {
        console.log('ERROR OCCURED: > > > > > > >  ', err.code);
        next(err)
      });
    }
  }
var mysql = require('mysql');
var express = require('express');
var bodyParser = require('body-parser')
var morgan = require('morgan');

//define class
class Sql {

  constructor(pool) {
    this.pool = pool;
  }

  exec(query, params) {
    let _this = this;
    return new Promise(function (resolve, reject) {
      _this.pool.query(query, params, function (error, rows, _fields) {
        if (error) {
          return reject(error);
        }
        return resolve(rows);
      });
    });
  }

}


//define class
class Api {

  constructor(mysqlPool, app) {
    this.mysql = new Sql(mysqlPool)
    this.app = app;

    // this.app.use(this.errMw)
    //console.log('IF ERROR MIDDLEWARE IS ADDED HERE - it was NEVER CALLED');

    /**************** add middleware and routes ****************/
    this.app.get('/', this.asyncWrap(this.root.bind(this)))
    this.app.use(this.errMw) // << USE ERROR MIDDLEWARE HERE
  }

  errMw(err, req, res, next) {

    res.status(400).json({error: err});
    next(err);
  }

  asyncWrap(fn) {
    return (req, res, next) => {
      Promise.resolve(fn(req, res, next))
        .catch((err) => {
          console.log('err > > > > >', err.message);
          next(err);
        });
    }
  }


  run(cbk) {
    this.app.listen(3000)
  }

  async root(req, res) {
    res.json(await this.mysql.exec('select * from customer', []))
  }

}


/**************** START : mysql,express,api -> run ****************/

let args = {}
args['host'] = 'localhost'
args['user'] = 'root'
args['password'] = 'secret'
args['database'] = 'models'

let mysqlPool = mysql.createPool(args)
let app = express()
//app.use(morgan('tiny'))
app.use(bodyParser.json())
app.use(bodyParser.urlencoded({
  extended: true
}))


let api = new Api(mysqlPool, app);
api.run()


/**************** END : mysql,express,api -> run ****************/