7

我正在使用 Express.js 和 MongoLab,并按照Heroku 设置让 MongoDB在生产中工作,并将此代码放入我的app.js中。

//Mongo on Heroku Setup
var mongo = require('mongodb');

var mongoUri = process.env.MONGOLAB_URI || 
  process.env.MONGOHQ_URL || 
  'mongodb://localhost/mydb'; 

mongo.Db.connect(mongoUri, function (err, db) {
  db.collection('mydocs', function(er, collection) {
    collection.insert({'mykey': 'myvalue'}, {safe: true}, function(er,rs) {
    });
  });
});

我的电子邮件表单(也在 app.js 中)有以下路由和字段:

//Routes

app.get('/', function(req, res) {
    res.render('index', {
        title: 'DumbyApp'
    });
});

//save new email
app.post('/', function(req, res){
    emailProvider.save({
        address: req.param('address')
    }, function( error, docs) {
        res.redirect('/')
    });
});

这会在索引页面上呈现新表单,并让我将其保存在本地,但不能在生产中保存,因为我不知道如何设置我的电子邮件集合。谁能帮我完成这个?全新使用 MongoDB 和 Node.js,因此可以使用一些帮助。

编辑:

在 MongoLab 数据库界面中,我制作了一个collection名为emails. 这是正确的做法吗?

编辑2:

这是在 app.js 中定义 EmailProvider 以及文件本身。

应用程序.js

 var express = require('express')
  , routes = require('./routes')
  , user = require('./routes/user')
  , http = require('http')
  , path = require('path')
  , EmailProvider = require('./emailprovider').EmailProvider;

var emailProvider= new EmailProvider('localhost', 27017);

emailprovider.js

var Db = require('mongodb').Db;
var Connection = require('mongodb').Connection;
var Server = require('mongodb').Server;
var BSON = require('mongodb').BSON;
var ObjectID = require('mongodb').ObjectID;

EmailProvider = function(host, port) {
  this.db= new Db('localdb', new Server(host, port, {safe: false}, {auto_reconnect: true}, {}));
  this.db.open(function(){});
};


EmailProvider.prototype.getCollection= function(callback) {
  this.db.collection('emails', function(error, email_collection) {
    if( error ) callback(error);
    else callback(null, email_collection);
  });
};

//save new email
EmailProvider.prototype.save = function(emails, callback) {
    this.getCollection(function(error, email_collection) {
      if( error ) callback(error)
      else {
        if( typeof(emails.address)=="undefined")
          emails = [emails];

        for( var i =0;i< emails.address;i++ ) {
          email = emails[i];
          email.created_at = new Date();
        }

        email_collection.insert(emails, function() {
          callback(null, emails);
        });
      }
    });
};

exports.EmailProvider = EmailProvider;
4

1 回答 1

6

虽然第一个代码框中的连接代码似乎是正确的,但 emailProvider 对象并未使用它。相反,在 app.js 中,EmailProvider 连接到 localhost:27017,并且数据库名称在 emailprovider.js 中硬编码为“localdb”。

您想要做的是使用您的 EmailProvider 中 MONGOLAB_URI 环境变量中提供的连接信息,其中已经包含主机、端口和数据库名称。

有很多方法可以做到这一点,但一种方法是将连接代码从第一个代码框移动到 EmailProvider 构造函数中,然后更改构造函数,使其采用 URI 而不是主机和端口。这样,您可以将 MONGOLAB_URI 变量传递给 app.js 中的构造函数。

于 2013-05-21T03:25:36.270 回答