Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/unity3d/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Html 使用Express连接到MongoDB_Html_Mongodb_Express - Fatal编程技术网

Html 使用Express连接到MongoDB

Html 使用Express连接到MongoDB,html,mongodb,express,Html,Mongodb,Express,我很难理解连接到MongoDB需要做些什么,这样才能将对象插入数据库。我对使用Express和MongoDB都是新手,还没有完全掌握它们 使用标准Express设置创建的My app.js如下所示 var express = require('express'); var path = require('path'); var favicon = require('serve-favicon'); var logger = require('morgan'); var cookieParser

我很难理解连接到MongoDB需要做些什么,这样才能将对象插入数据库。我对使用Express和MongoDB都是新手,还没有完全掌握它们

使用标准Express设置创建的My app.js如下所示

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

var MongoClient = require('mongodb').MongoClient;
var ObjectID = require('mongodb').ObjectID;
var url = 'mongodb://localhost:27017/contacts'

var index = require('./routes/index');

var app = express();

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

// uncomment after placing your favicon in /public
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', index);

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

// error handler
app.use(function(err, req, res, next) {
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

module.exports = app;
我的index.js如下所示,我希望在/mailer发出post请求时,连接到MongoDB以设置插入

var express = require('express');
var router = express.Router();
var url = 'mongodb://localhost:27017/contacts';
var contacts;

/* GET home page. */
var start = function(req, res, next){
  console.log("Starting!");
  res.render('mailer',{});
}

router.get('/', start);
router.get('/mailer', start);

/* Post mailer Page insert into database*/
 router.post('/mailer', function(req, res, next){
   res.render('thanks');
   console.log("Welcome to the Thank You Page");

   MongoClient.connect(url, function(err, db){
     if(err == NULL){
       console.log("Connected to database");

       // parse the body of the page and set up object to send to the                
       // database  

    }
   });

   });



 router.get('/contact', function(req, res){
   res.render('contact', {});
 })

module.exports = router;
*对于express

 var mongo = require('mongodb');
        var MongoClient = mongo.MongoClient;    
        MongoClient.connect('mongodb://'+DB_USERNAME+':'+DB_PASSWORD+'@'+DB_HOST+':'DB_PORT+'/'+DB_NAME,function(err, db){  
              if(err) 
                console.log(err);
              else
              {
                console.log('Mongo Conn....');

              }
            });
//对于express的本地服务器 //在本地服务器中,不需要DBPASSWOAD和DBusername

MongoClient.connect('mongodb://'+DB_HOST+':'+DB_PORT+'/'+DB_NAME,function(err, db){  
      if(err) 
        console.log(err);
      else
      {
        console.log('Mongo Conn....');

      }
    });

你的代码是超级混乱,我可以显示你我的配置,你可以参考

db.js
import mongoose from 'mongoose';

export default function connectDB() {
    mongoose.Promise = global.Promise;
    mongoose.connect('mongodb://localhost:27017/contacts');
    mongoose.connection.once('open', function () {
        console.log('mongodb connected.');
    });
};


app.js
import connectDB from "db.js";

connectDB();


user.model.js
import mongoose from 'mongoose';

const schema = mongoose.Schema({
    email: {type: String, required: true},
    mobile: {type: String},
    password: {type: String, required: true},
});

const User = mongoose.model('User', schema, 'user');

export default User;

然后在您的路由器文件中,您可以调用User.find()或User.update或…

通常,您不希望每次查询/插入时都创建一个新的mongo连接,但为了简单起见,这是可以的。除此之外,您似乎走上了正确的道路,我很难理解您到底需要什么帮助。每次尝试连接到数据库时,我都会收到一个错误,错误是:发送邮件后无法设置邮件头。我如何设置它,使它只连接一次,而不是每次我设置一个帖子。这是非常基本的东西,很难用简短的评论或回答来解释。虽然有很多关于这方面的教程,但要找到一些通常如何做的例子应该很容易。@svens“如果你不能向一个六岁的孩子解释,你自己也不明白。”@CharlieMartin再次阅读。这并不难解释,只是在StackOverflow帖子中从零开始需要付出很多努力(对我来说太多了)。这对OP来说是个很好的建议,以防他在这里得不到好的答案。他的代码中也存在多个问题,这同样不太适合于如此多的问题。我认为目前的答案足以证明这一点。OP最好是在聊天室提问,或者按照我的建议完成一个好的教程。这真的没有那么混乱,也不能解决他的问题,这与express middleware order比MongoI更相关。我不太理解“与express middleware order比Mongo更相关”的意思,但是路由器功能中的“MongoClient.connect”显然不是一个好的编码习惯。OP说他收到了“错误:发送后无法设置头”,这意味着他对一个请求发送了两个响应