Nodejs / Express - 启动我的应用程序:不推荐使用 express.createServer()

Posted

技术标签:

【中文标题】Nodejs / Express - 启动我的应用程序:不推荐使用 express.createServer()【英文标题】:Nodejs / Express - Launching my app: express.createServer() is deprecated 【发布时间】:2012-11-10 01:02:39 【问题描述】:

我下载了一个节点应用程序来测试和使用。我搜索了一下,发现 Express 有点过时了。有人可以帮我修复实现的代码吗?

这里是代码

/**
 * Module dependencies.
 */

// base dependencies for app
var express = require('express')
  , routes = require('./routes')
  , DB = require('./accessDB').AccessDB
  , passport = require('passport')
  , mongoose = require('mongoose')
  , mongoStore = require('connect-mongodb');

var app = module.exports = express.createServer();
global.app = app;

var DB = require('./accessDB');
var conn = 'mongodb://localhost/CrowdNotes';
var db;

// SocketIO Configuration
//var io = require('socket.io').listen(app);
//
//io.sockets.on('connection', function(socket) 
//  socket.on('user note', function (note) 
//    console.log(note);
//  );
//);

// Configuration
app.configure(function()
  app.set('views', __dirname + '/views');
  app.set('view engine', 'jade');
  app.use(express.cookieParser());
  app.use(express.bodyParser());
  app.use(express.methodOverride());
  app.use(require('stylus').middleware( src: __dirname + '/public' ));
  app.use(express.session( 
    store: mongoStore(conn)
  , secret: 'applecake'
  , function() 
    app.use(app.router);
  ));
  app.use(passport.initialize());
  app.use(passport.session());
  app.use(express.static(__dirname + '/public'));
);

db = new DB.startup(conn);

app.configure('development', function()
  app.use(express.errorHandler( dumpExceptions: true, showStack: true )); 
);

app.configure('production', function()
  app.use(express.errorHandler()); 
);

// Routes
require('./routes')(app);

app.listen(3000);
console.log("Express server listening on port %d in %s mode", app.address().port, app.settings.env);

这是我通过node app运行应用程序后收到的错误

C:\CrowdNotes>node app
Warning: express.createServer() is deprecated, express
applications no longer inherit from http.Server,
please use:

  var express = require("express");
  var app = express();


C:\CrowdNotes\app.js:63
console.log("Express server listening on port %d in %s mode", app.address().po
                                                                  ^
TypeError: Object function app(req, res) app.handle(req, res);  has no method
'address'
    at Object.<anonymous> (C:\CrowdNotes\app.js:63:67)
    at Module._compile (module.js:449:26)
    at Object.Module._extensions..js (module.js:467:10)
    at Module.load (module.js:356:32)
    at Function.Module._load (module.js:312:12)
    at Module.runMain (module.js:492:10)
    at process.startup.processNextTick.process._tickCallback (node.js:244:9)

C:\CrowdNotes>

已修复。

我现在正在注册,并使用我的新“用户”数据登录并收到此错误:

ReferenceError: C:\CrowdNotes\views\account.jade:6
    4|   div#header 
    5|     h2 CrowdNotes
  > 6|     p Hi, #currentUser.name.first! 
    7| 
    8|   - if (myEvent)
    9|     p.center My Event: #myEvent.name 

currentUser is not defined
    at eval (eval at <anonymous> (C:\CrowdNotes\node_modules\jade\lib\jade.js:176:8))
    at exports.compile (C:\CrowdNotes\node_modules\jade\lib\jade.js:181:12)
    at Object.exports.render (C:\CrowdNotes\node_modules\jade\lib\jade.js:216:14)
    at View.exports.renderFile [as engine] (C:\CrowdNotes\node_modules\jade\lib\jade.js:243:13)
    at View.render (C:\CrowdNotes\node_modules\express\lib\view.js:75:8)
    at Function.app.render (C:\CrowdNotes\node_modules\express\lib\application.js:500:10)
    at ServerResponse.res.render (C:\CrowdNotes\node_modules\express\lib\response.js:716:7)
    at module.exports.getAccount (C:\CrowdNotes\routes\index.js:47:11)
    at Promise.module.exports.getMyEvent (C:\CrowdNotes\accessDB.js:54:7)
    at Promise.addBack (C:\CrowdNotes\node_modules\mongoose\lib\promise.js:128:8)

我想知道这是否也是某种形式的语法错误?不知道这里出了什么问题,因为我认为代码都排好了。

我正在使用这里的代码:https://github.com/rockbot/crowdnotes

【问题讨论】:

请为另一个问题提交另一个问题 【参考方案1】:

错误中给出了解决方案。

警告:express.createServer() 已弃用,express 应用程序不再从 http.Server 继承 请使用:

  var express = require("express");
  var app = express();

所以你必须这样做。

var express = require('express')
  , http = require('http');

var app = express(); 
var server = http.createServer(app);

【讨论】:

感谢您的回复。我在上面的帖子中添加了一个新错误,你知道为什么会这样吗? 这个错误是因为模板找不到对象 currentUser 的定义位置 有趣的是,在这个例子中使用 currentUser 时很难遵循它所采用的路径。例如,就文件而言,我看不到 currentUser 下一步会去哪里。 在 index.js 文件中,getAccount 函数正在从请求对象中设置 currentUser。只需登录以查看请求是否存在用户字段 我已经添加到getAccount函数if(req.user != null)然后执行该函数,但我不知道这是否是正确的方法,或者如果没有currentUser返回什么.很抱歉打扰你。【参考方案2】:

另一个可能的解决方案是安装 express 2.5.8 作为依赖项。

添加到 package.json:

    
    "name": "authentication"
  , "version": "0.0.1"
  , "private": true
  , "dependencies": 
      "express": "2.5.8"
    , "jade": ">= 0.26.1"
  

然后运行

npm install

【讨论】:

【参考方案3】:

这个简单的程序就可以完成:

var express = require('express');
var app = express();
app.get('/',
    function(req,res)
    
        res.send("express");
    
);
app.listen(3333);

效果很好。

【讨论】:

【参考方案4】:

我已经在使用下面的 sn-p 并且工作正常:

var express =require("express");
var http = require("http");

var app = express();
//app routers here 
...
var httpServer = http.Server(app);

httpServer.listen(PORT, function(err)

);

【讨论】:

【参考方案5】:
var express = require('express');
var app = express();
app.listen(your_port_number);

使用较新版本的 express(express 4.x),您无需创建服务器。 app.listen 在内部这样做。参考https://expressjs.com/en/4x/api.html#app.listen

【讨论】:

以上是关于Nodejs / Express - 启动我的应用程序:不推荐使用 express.createServer()的主要内容,如果未能解决你的问题,请参考以下文章

在 Nodejs Express 应用程序中单击按钮时启动/停止 cronjob

nodejs+express+ejs生成项目

create-react-app + nodejs (express) 服务器

Nodejs - 小型 Express 服务器 + trayicon + pkg

Heroku节点应用程序未启动

在heroku上部署Nodejs+Express+React+Webpack应用