Express JS无法识别环境

时间:2013-09-24 22:33:49

标签: javascript node.js express environment-variables

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

应用程序/    配置/       app.js       env.js    server.js

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

Gist Codes

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);
    });
};

node server.js

输出

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

3 个答案:

答案 0 :(得分:2)

默认情况下,process.env.NODE_ENV未定义。如果您在测试环境中运行节点,例如(NODE_ENV=test node app.js),则不会出现此问题。

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

if (app.settings.env === 'development') process.env.NODE_ENV = 'development';

答案 1 :(得分:0)

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

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

似乎相反。

答案 2 :(得分:0)

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