首页 > 解决方案 > 来自 nodejs 应用程序 mongoose.save() 块并且什么都不做?

问题描述

我正在尝试使用一个非常基本的 MongoDB 方法,即使用 mongoose 将文档保存在数据库中。

1.我在centos 7中安装了我的MongoDB

2.在 Mongo shell 上创建一个数据库,使用:使用 mydatabase 并像往常一样在其中插入一个文档。

3.安装猫鼬并在我的nodejs应用程序和MongoDB之间建立连接:

mongoose.connect('mongodb://localhost:27017/goClass_test', {
  useUnifiedTopology: true,
  useNewUrlParser: true,
});

4. 测试连接,一切正常:

db.once('open', () => {
  console.log('DB Connected');
});
  1. 正常导入模型模式:

var { Classe } = require('../DBModels/GoClassDBModels/classes');

  1. 尝试像这样添加新文档:
var newClasse = new Classe({
     label: 'hello',
     level: 'level',
   });
newClasse.save()

我的模型是:

const mongoose = require('mongoose');
const { Schema } = require('mongoose');
var ObjectId = mongoose.Schema.Types.ObjectId;

var classSchema = new Schema({
  directeurId: {
    type: ObjectId,
  },
  label: {
    type: String,
  },
  level: {
    type: String,
  },
  studentNbr: {
    type: String,
  },
});

var Classe = mongoose.model('Classes', classSchema);

module.exports = { Classe };

服务器.JS:

const mongoose = require('mongoose');
const express = require('express');
const bodyParser = require('body-parser');
const http = require('http');
const cookieParser = require('cookie-parser');
const _ = require('lodash');

var app = express();
var server = http.createServer(app);
server.listen(80, () => {
  console.log('server is started on 80');
});

mongoose.connect('mongodb://localhost:27017/goClass_test', {
  useUnifiedTopology: true,
  useNewUrlParser: true,
});

console.log(mongoose.connection.host);
console.log(mongoose.connection.port);

let db = mongoose.connection;

db.once('open', () => {
  console.log('DB Connected');
});

db.on('error', (err) => {
  console.log(err);
});

var { Classe } = require('../DBModels/GoClassDBModels/classes');

const goClasseRouteDirecteur = require('./GOClassRoutes/DirecteurRoutes/subRoutesClass');

app.use(bodyParser.json());
app.use(cookieParser(['lakkini.com']));
app.use(
  bodyParser.urlencoded({
    extended: false,
  })
);

app.use(function (req, res, next) {
  res.set(
    'Cache-Control',
    'no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0'
  );
  next();
});

app.set('view engine', 'hbs');
app.use(express.static('/home/admin/SMS'));
app.use(express.static('/home/admin/assets'));

app.get('/', (req, res) => {
  res.render('SMS/dashboard.hbs');
});

app.get('/classes', (req, res) => {
  res.render('SMS/classes.hbs');
});

app.get('/inscription', (req, res) => {
  res.render('SMS/inscriptions.hbs');
});

app.post('/saveClasse', (req, res) => {
  var newClasse = new Classe({
    label: 'hello',
    level: 'level',
  });
  console.log('im gonna save the new class');
  newClasse.save((err, response) => {
    if (err) console.log(err);
    else console.log(response);
  });
});

问题是:什么都没发生。没有插入任何文档,也没有错误。请给我建议好吗?

PS:我正在尝试从没有 HTTPS 的 HTTP 服务器请求。

这会影响我的请求并阻止保存到数据库吗?

结果: 请点击查看结果图片

标签: node.jsmongodbmongoosecentos7mongoose-schema

解决方案


由于没有为猫鼬连接提供整个文件以及调用保存功能的位置,假设您已正确构建它,我正在给出我的答案。我能够做到这一点,

架构(与您的相同):

const mongoose = require("mongoose");
const { Schema } = require("mongoose");
var ObjectId = mongoose.Schema.Types.ObjectId;

var classSchema = new Schema({
  directeurId: {
    type: ObjectId,
  },
  label: {
    type: String,
  },
  level: {
    type: String,
  },
  studentNbr: {
    type: String,
  },
});

var Classe = mongoose.model("Classes", classSchema);

module.exports = { Classe };

插入函数:

mongoose.connect("mongodb://localhost:27017/goClass_test", {
    useUnifiedTopology: true,
    useNewUrlParser: true,
  });

  var db = mongoose.connection;
  db.on("error", console.error.bind(console, "connection error:"));

  db.once("open", () => {
    console.log("DB Connected");
    var newClasse = new Classe({
      label: "hello",
      level: "level",
    });

    newClasse.save();
  });

更新:

服务器.JS

const mongoose = require("mongoose");
const express = require("express");
const bodyParser = require("body-parser");
const http = require("http");
const cookieParser = require("cookie-parser");
const _ = require("lodash");

var app = express();
var server = http.createServer(app);
server.listen(80, () => {
  console.log("server is started on 80");
});

mongoose.connect("mongodb://localhost:27017/goClass_test", {
  useUnifiedTopology: true,
  useNewUrlParser: true,
});

console.log(mongoose.connection.host);
console.log(mongoose.connection.port);

let db = mongoose.connection;

db.once("open", () => {
  console.log("DB Connected");
});

db.on("error", (err) => {
  console.log(err);
});

var { Classe } = require("./models/Classe");

// const goClasseRouteDirecteur = require('./GOClassRoutes/DirecteurRoutes/subRoutesClass');

app.use(bodyParser.json());
app.use(cookieParser(["lakkini.com"]));
app.use(
  bodyParser.urlencoded({
    extended: false,
  })
);

app.use(function (req, res, next) {
  res.set(
    "Cache-Control",
    "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0"
  );
  next();
});

app.set("view engine", "hbs");
// app.use(express.static("/home/admin/SMS"));
// app.use(express.static("/home/admin/assets"));

// app.get('/', (req, res) => {
//     res.render('SMS/dashboard.hbs');
//   });

//   app.get('/classes', (req, res) => {
//     res.render('SMS/classes.hbs');
//   });

//   app.get('/inscription', (req, res) => {
//     res.render('SMS/inscriptions.hbs');
//   });

app.post("/saveClasse", (req, res) => {
  var newClasse = new Classe({
    label: "hello",
    level: "level",
  });
  console.log("im gonna save the new class");

  newClasse.save((err, response) => {
    if (err) console.log(err);
    else console.log("RESPONSE" + response);
  });
});
在此处输入图像描述


推荐阅读