我的应用程序文件夹结构是这样的。
应用程序/ 配置/ 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);
});
};
node server.js
/usr/bin/node app.js
App is Up at 3000 as undefined
答案 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
未定义。没问题。