似乎尝试了所有可用的解决方案,即使有些人声称Azure已在内部修复此问题,但我无法让它工作,生产部署每次都会给我500个错误。部署本地工作。这是我的app.js,它基本上是“开箱即用”的快递4.12.2
var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var routes = require('./routes/index');
var users = require('./routes/users');
var app = express();
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
// uncomment after placing your favicon in /public
//app.use(favicon(__dirname + '/public/favicon.ico'));
app.set('port', process.env.PORT || 1337);
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', routes);
app.use('/users', users);
// catch 404 and forward to error handler
app.use(function(req, res, next) {
var err = new Error('Not Found');
err.status = 404;
next(err);
});
// error handlers
// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
app.use(function(err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: err
});
});
}
// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: {}
});
});
module.exports = app;
app.listen(app.get('port'), function(){
console.log('Express server listening on port ' + app.get('port'));
});
答案 0 :(得分:1)
我怀疑您可能会在日志中收到此错误。
Error: ENOENT, open 'D:\home\site\wwwroot\bin\views\layouts\main.handlebars'
at Error (native)
请注意views文件夹的路径。
您可以尝试删除www文件。查看Express docs中关于如何使用的最后几段。
此外,我发现如果您拥有图像和字体等资源,则需要添加app.use(express.static('public'));
- 否则会无声地失败。
答案 1 :(得分:0)
确保您的入口点位于根文件夹中。
在我的情况下,我的入口点是' ./ bin / www',我不得不手动将此文件移动到root并更新Web.config中的和部分以使其正常工作。
进行这些更改后再次部署。
答案 2 :(得分:0)
以下问题提供了几个解决方案
Azure NodeJS Error: ENOENT, open 'D:\home\site\wwwroot\bin\views\'
现在我只是在app.js的顶部附近使用了以下内容 process.chdir(__目录名);
答案 3 :(得分:0)
我知道处理这种情况非常棘手。
如何检查实际错误而不是500
祝你好运。