node app.js报错
发布于 11 年前 作者 edagarli 9188 次浏览 最后一次编辑是 8 年前
Failed to load c++ bson extension, using pure JS version

/home/justhacker/tools/codes/microblog/node_modules/express/lib/express.js:89
throw new Error('Most middleware (like ' + name + ') is no longer bundle ^
Error: Most middleware (like session) is no longer bundled with Express and must be installed separately. Please see https://github.com/senchalabs/connect#middleware.

at Function.Object.defineProperty.get (/home/justhacker/tools/codes/microblog/node_modules/express/lib/express.js:89:13)
at module.exports (/home/justhacker/tools/codes/microblog/node_modules/connect-mongo/lib/connect-mongo.js:30:22)
at Object. (/home/justhacker/tools/codes/microblog/app.js:14:42)
at Module._compile (module.js:449:26)
at Object.Module._extensions..js (module.js:467:10)
at Module.load (module.js:349:32)
at Function.Module._load (module.js:305:12)
at Function.Module.runMain (module.js:490:10)
at startup (node.js:124:16)
at node.js:807:3

官方文档。

Middleware

As of 4.x, Express no longer depends on Connect. All of Express’ previously included middleware are now in separate repos. Please view the list of middleware. The only included middleware is now express.static().

但是我的代码里面没有用。

var express = require('express');
var path = require('path');
var favicon = require('static-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var session = require('express-session');
var bodyParser = require('body-parser');

var util = require('util');

var routes = require('./routes/index');
var users = require('./routes/users');
//var connect = require('connect');
var MongoStore = require('connect-mongodb');
var setting = require('./setting');

var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');

app.use(favicon());
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded());
//app.use(express.methodOverride());
app.use(cookieParser());
app.use(session({
  secret: setting.cookieSecret,
  store: new MongoStore({
    db: setting.db
  })
}));
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', routes);
app.use('/users', users);

/// catch 404 and forwarding to error handler
app.use(function(req, res, next) {
  var err = new Error('Not Found');
  err.status = 404;
  next(err);
});

/// error handlers

// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
  app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
      message: err.message,
      error: err
    });
  });
}

// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
  res.status(err.status || 500);
  res.render('error', {
    message: err.message,
    error: {}
  });
});

module.exports = app;
3 回复

没有看到监听端口写在哪

帮楼主格式化了一遍代码… 话说报错的是 14 行是被注释掉的那行代码吗?

at Object. (/home/justhacker/tools/codes/microblog/app.js:14:42

已经解决了。。 Failed to load c++ bson extension, using pure JS version

现在报这个错误。。

界面上显示 Cannot read property ‘findOne’ of null

undefined

TypeError: Cannot read property ‘findOne’ of null at MongoStore.MONGOSTORE.get (/home/justhacker/tools/codes/microblog/node_modules/connect-mongodb/lib/connect-mongodb.js:115:14) at Layer.session [as handle] (/home/justhacker/tools/codes/microblog/node_modules/express-session/index.js:328:11) at trim_prefix (/home/justhacker/tools/codes/microblog/node_modules/express/lib/router/index.js:226:17) at /home/justhacker/tools/codes/microblog/node_modules/express/lib/router/index.js:198:9 at Function.proto.process_params (/home/justhacker/tools/codes/microblog/node_modules/express/lib/router/index.js:251:12) at next (/home/justhacker/tools/codes/microblog/node_modules/express/lib/router/index.js:189:19) at Layer.cookieParser [as handle] (/home/justhacker/tools/codes/microblog/node_modules/cookie-parser/index.js:46:5) at trim_prefix (/home/justhacker/tools/codes/microblog/node_modules/express/lib/router/index.js:226:17) at /home/justhacker/tools/codes/microblog/node_modules/express/lib/router/index.js:198:9 at Function.proto.process_params (/home/justhacker/tools/codes/microblog/node_modules/express/lib/router/index.js:251:12)

回到顶部