Nodejs: Как отловить исключение из промежуточного программного обеспечения? - PullRequest
5 голосов
/ 31 октября 2010

Я использую node.js и промежуточное ПО компилятора "less":

app.configure(function() {
    // ...
    app.use(express.compiler({ src: __dirname + '/public', enable: ['less'] }))
    // ...
})

Теперь у меня есть неисправный .less -файл, но я не могу найти никаких документов о томчтобы получить сообщение об ошибке.Страница, которую я получаю, это:

<html>
  <head>
    <title>[object Object]</title>
    <style>
      /* css stuff */
    </style>
  </head>
  <body>
    <div id="wrapper">
      <h1>Connect</h1>

      <h2><em>500</em> [object Object]</h2>
      <ul id="stacktrace"></ul>
    </div>
  </body>
</html>

Так что это не полезно.У кого-нибудь есть идея?

1 Ответ

4 голосов
/ 31 октября 2010

Ах, хорошо, понял. Хитрость заключается в том, чтобы оставить ошибку разработкиHandler

app.configure('development', function() {
    // app.use(express.errorHandler({ dumpExceptions: true, showStack: true }));
});

Кажется, что он проглатывает вызовы app.error, поэтому теперь это работает:

app.error(function(err, req, res, next) {
    sys.puts("APP.ERROR:" + sys.inspect(err));
    next(err);
});

Это показывает правильную ошибку вместо [объект объекта]

...