Express Generator - TypeError: app.set is not a function
Express Generator - TypeError: app.set is not a function
我首先用 Node/Express 自己创建了一个 API 来学习大多数程序员使用的 'naive' 方法。它运行良好,我决定尝试使用 express-generator。
设置好所有内容后,应用程序运行正常。
我添加了我的一堆代码(主要在 app.js 中并导入了一些路由来尝试),我没有在设置 express 的 bin/www 中进行任何更改。
但是在启动时我得到了指向这个特定文件的错误 bin/www :
app.set('port', port);
^
TypeError: app.set is not a function
我不知道为什么自动生成的这部分代码现在不想工作了。
这里是 2 个主体文件
bin/www : (生成-未修改)
#!/usr/bin/env node
/**
* Module dependencies.
*/
var app = require('../app');
var debug = require('debug')('API:server');
var http = require('http');
/**
* Get port from environment and store in Express.
*/
var port = normalizePort(process.env.PORT || '3000');
app.set('port', port);
/**
* Create HTTP server.
*/
var server = http.createServer(app);
/**
* Listen on provided port, on all network interfaces.
*/
server.listen(port);
server.on('error', onError);
server.on('listening', onListening);
/**
* Normalize a port into a number, string, or false.
*/
function normalizePort(val) {
var port = parseInt(val, 10);
if (isNaN(port)) {
// named pipe
return val;
}
if (port >= 0) {
// port number
return port;
}
return false;
}
/**
* Event listener for HTTP server "error" event.
*/
function onError(error) {
if (error.syscall !== 'listen') {
throw error;
}
var bind = typeof port === 'string'
? 'Pipe ' + port
: 'Port ' + port;
// handle specific listen errors with friendly messages
switch (error.code) {
case 'EACCES':
console.error(bind + ' requires elevated privileges');
process.exit(1);
break;
case 'EADDRINUSE':
console.error(bind + ' is already in use');
process.exit(1);
break;
default:
throw error;
}
}
/**
* Event listener for HTTP server "listening" event.
*/
function onListening() {
var addr = server.address();
var bind = typeof addr === 'string'
? 'pipe ' + addr
: 'port ' + addr.port;
debug('Listening on ' + bind);
}
app.js :
// Module dependencies
const express = require('express');
const cluster = require('express-cluster'); // fork the service on different thread
const helmet = require('helmet'); // Secure HTTP header
const cors = require('cors');
const path = require('path');
const bodyParser = require('body-parser'); // Help to easily parse the body of req/res
const port = process.env.PORT || 3000;
const mongoose = require('mongoose'); // Manage MongoDB request
cluster(function(worker) {
var app = express();
// MongoDB config
const config = require('./misc/config/index'); // Config variable like MongoDB credential
mongoose.Promise = global.Promise;
mongoose.connect(config.getDBConnectionString()); // Config to cnx to mongodb
// mongoose.connect(config.getDBConnectionString(), { config: { autoIndex: false } });
// Middleware
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: true}));
app.use(helmet.frameguard()); // Default Value - Help to secure request by putting some setting in the header
app.use(cors()); // Handling Cross Origin Ressource Sharing
// Logfile
const log = require('./misc/log/log');
app.use(log);
// Config Landingpage to /
app.use('/assets', express.static(path.join(__dirname, 'public')));
app.set('view engine', 'ejs');
// Entry point
const entryPoint = require('./routes/entryPoint');
app.get('/', entryPoint.index);
app.get('/api', function (req, res) {
res.redirect(301, '/');
})
// API Key handler
const auth = require('./misc/auth/auth');
app.use(auth);
// List
const list = require('./routes/list/listRouter'); // Get List endpoints
// app.use('/api/list', list);
// Map
const map = require('./routes/map/mapRouter'); // Get List endpoints
// app.use('/api/map', map);
module.exports = app;
}, {count: 2})
我导出包含 express() 的应用程序。所以我在这里缺少一些东西,但我看不到什么。
问题是由以下设置引起的:
cluster(function(worker) {
var app = express();
...
module.exports = app;
}, { ... });
因为 cluster
将异步调用 "worker function",所以导出也是异步完成的,这对 bin/www
来说太晚了。除此之外,worker 函数将 运行 在一个单独的进程中,这也使事情变得复杂。
因为 bin/www
的功能相对简单,您可以选择将其内容(或至少是其功能的要点)移动到 app.js
,然后启动您的应用node app.js
。您甚至可以用一个简单的脚本替换 bin/www
:
#!/usr/bin/env node
require('../app');
或者,您可以保持代码不变,并依靠外部程序在可用 CPU 之间提供负载平衡。一个流行的解决方案是 pm2
,尽管它并不适合所有人(看起来有点碰运气)。
如果需要传递环境变量,可以通过命令行进行:
$ env API_KEY=XXX pm2 start app.js
或为您的应用创建 a configuration file。
还有一个名为 dotenv
的包,它允许您的 Node 应用程序直接从文件中读取环境变量。
我首先用 Node/Express 自己创建了一个 API 来学习大多数程序员使用的 'naive' 方法。它运行良好,我决定尝试使用 express-generator。
设置好所有内容后,应用程序运行正常。
我添加了我的一堆代码(主要在 app.js 中并导入了一些路由来尝试),我没有在设置 express 的 bin/www 中进行任何更改。
但是在启动时我得到了指向这个特定文件的错误 bin/www :
app.set('port', port);
^
TypeError: app.set is not a function
我不知道为什么自动生成的这部分代码现在不想工作了。
这里是 2 个主体文件
bin/www : (生成-未修改)
#!/usr/bin/env node
/**
* Module dependencies.
*/
var app = require('../app');
var debug = require('debug')('API:server');
var http = require('http');
/**
* Get port from environment and store in Express.
*/
var port = normalizePort(process.env.PORT || '3000');
app.set('port', port);
/**
* Create HTTP server.
*/
var server = http.createServer(app);
/**
* Listen on provided port, on all network interfaces.
*/
server.listen(port);
server.on('error', onError);
server.on('listening', onListening);
/**
* Normalize a port into a number, string, or false.
*/
function normalizePort(val) {
var port = parseInt(val, 10);
if (isNaN(port)) {
// named pipe
return val;
}
if (port >= 0) {
// port number
return port;
}
return false;
}
/**
* Event listener for HTTP server "error" event.
*/
function onError(error) {
if (error.syscall !== 'listen') {
throw error;
}
var bind = typeof port === 'string'
? 'Pipe ' + port
: 'Port ' + port;
// handle specific listen errors with friendly messages
switch (error.code) {
case 'EACCES':
console.error(bind + ' requires elevated privileges');
process.exit(1);
break;
case 'EADDRINUSE':
console.error(bind + ' is already in use');
process.exit(1);
break;
default:
throw error;
}
}
/**
* Event listener for HTTP server "listening" event.
*/
function onListening() {
var addr = server.address();
var bind = typeof addr === 'string'
? 'pipe ' + addr
: 'port ' + addr.port;
debug('Listening on ' + bind);
}
app.js :
// Module dependencies
const express = require('express');
const cluster = require('express-cluster'); // fork the service on different thread
const helmet = require('helmet'); // Secure HTTP header
const cors = require('cors');
const path = require('path');
const bodyParser = require('body-parser'); // Help to easily parse the body of req/res
const port = process.env.PORT || 3000;
const mongoose = require('mongoose'); // Manage MongoDB request
cluster(function(worker) {
var app = express();
// MongoDB config
const config = require('./misc/config/index'); // Config variable like MongoDB credential
mongoose.Promise = global.Promise;
mongoose.connect(config.getDBConnectionString()); // Config to cnx to mongodb
// mongoose.connect(config.getDBConnectionString(), { config: { autoIndex: false } });
// Middleware
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: true}));
app.use(helmet.frameguard()); // Default Value - Help to secure request by putting some setting in the header
app.use(cors()); // Handling Cross Origin Ressource Sharing
// Logfile
const log = require('./misc/log/log');
app.use(log);
// Config Landingpage to /
app.use('/assets', express.static(path.join(__dirname, 'public')));
app.set('view engine', 'ejs');
// Entry point
const entryPoint = require('./routes/entryPoint');
app.get('/', entryPoint.index);
app.get('/api', function (req, res) {
res.redirect(301, '/');
})
// API Key handler
const auth = require('./misc/auth/auth');
app.use(auth);
// List
const list = require('./routes/list/listRouter'); // Get List endpoints
// app.use('/api/list', list);
// Map
const map = require('./routes/map/mapRouter'); // Get List endpoints
// app.use('/api/map', map);
module.exports = app;
}, {count: 2})
我导出包含 express() 的应用程序。所以我在这里缺少一些东西,但我看不到什么。
问题是由以下设置引起的:
cluster(function(worker) {
var app = express();
...
module.exports = app;
}, { ... });
因为 cluster
将异步调用 "worker function",所以导出也是异步完成的,这对 bin/www
来说太晚了。除此之外,worker 函数将 运行 在一个单独的进程中,这也使事情变得复杂。
因为 bin/www
的功能相对简单,您可以选择将其内容(或至少是其功能的要点)移动到 app.js
,然后启动您的应用node app.js
。您甚至可以用一个简单的脚本替换 bin/www
:
#!/usr/bin/env node
require('../app');
或者,您可以保持代码不变,并依靠外部程序在可用 CPU 之间提供负载平衡。一个流行的解决方案是 pm2
,尽管它并不适合所有人(看起来有点碰运气)。
如果需要传递环境变量,可以通过命令行进行:
$ env API_KEY=XXX pm2 start app.js
或为您的应用创建 a configuration file。
还有一个名为 dotenv
的包,它允许您的 Node 应用程序直接从文件中读取环境变量。