1

我的应用程序文件夹结构是这样的。

app/ config/ app.js env.js server.js

每当我开始运行我的 app.js 文件时,它都会让我的服务器以未定义的方式启动。这是代码的要点。

要点代码

server.js    
// Module dependencies.
var http = require('http'),
    app = require('./config/app')();

// Start server
app.listen(app.get('port'), function(){
    console.log('App is Up at '+ app.get('port') + ' as ' + process.env.NODE_ENV);
});

config/app.js
var express  =  require('express'),
    path  =  require('path'),
    ejs  =  require('ejs');

module.exports = function() {
    var app = express();
    var publicDir = path.join(__dirname, '../public');

    // Store all environment variables
    app.set('port', process.env.PORT || 3000);

    // Basic configuration
    app.configure(function() {
        app.use(express.logger('dev'));
        app.use(express.bodyParser());
        app.use(express.methodOverride());
        app.use(app.router);
        app.use(express.static(publicDir));
    });

    // Environment specific configuration
    require('./env')(app);

    return app;
};
config/env.js
var express = require('express'),
    hbsPrecompiler = require('handlebars-precompiler'),
    path = require('path');

module.exports = function(app) {
    // development compile Handlebars and show errors
    app.configure('development', function(){
        app.set('db-uri', process.env.MONGOLAB_URI || 'mongodb://localhost/App');

        hbsPrecompiler.watchDir(
            path.join(__dirname, "../public/templates"),
            path.join(__dirname, "../public/templates/compiled/templates.js"),
            ['handlebars', 'hbs']
        );
        app.use(express.errorHandler());
    });

    app.configure('production', function(){
        app.set('db-uri', process.env.MONGOLAB_URI);
    });
};

节点服务器.js

输出

/usr/bin/node app.js
App is Up at 3000 as undefined
4

3 回答 3

2

默认情况下,process.env.NODE_ENV未定义。如果您在测试环境中运行 node,例如 ( NODE_ENV=test node app.js),您就不会遇到这个问题。

我建议你在你的module.exports函数中添加这一行:

if (app.settings.env === 'development') process.env.NODE_ENV = 'development';
于 2013-09-24T23:08:49.350 回答
0

这看起来与您提到的文件夹结构不同:

app = require('./config/app')();

好像反过来了。

于 2013-09-24T22:37:00.117 回答
0

这正如预期的那样。除非您明确设置它,否则默认情况下没有 NODE_ENV 环境变量,因此process.env.NODE_ENV未定义。这没有问题。

于 2013-09-24T23:17:31.403 回答