Создание соединения MongoDB с mongoose - PullRequest
0 голосов
/ 15 мая 2018

Я отчаянно пытаюсь создать соединение с mongoDB со стеком MEAN, используя mongoose. Мой экземпляр MongoDB (mongod) работает, и я могу использовать mongo.exe и проверить его, вставив некоторые документы, он работал нормально. Но у меня проблемы с созданием соединения с MongoDB с помощью mongoose, и вставка документа методом .save () тоже не работает ... Сначала я хотел попробовать мой метод POST, создал функцию и протестировал ее, создав некоторые значения в POSTMAN. Но в мою базу данных MongoDB не было вставлено никаких документов.

Это мой файл app.js:

var express = require('express');
var app     = express();
var bodyParser = require("body-parser");
var morgan = require("morgan");
//var routes = require('./routes');
//var cors = require('cors')

//configure app
app.use(morgan('dev')); //log requests to the console

//configure body parser
app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());

var port = process.env.PORT || 5000;

//DATABASE SETUP
var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/DNZ'); //connect to uor datbaase

//Handle the connection event
var db = mongoose.connection;
db.on('error', console.error.bind(console, 'connection error:'));

db.once('open', function() {
console.log("DB connection alive");
});

//DNZ models live here
var FA = require('./models/DNZmodels/FA');

//ROUTES FOR OUR API
//=============================================================================

//create our router
var router = express.Router();

//middleware to use for all requests
router.use(function(req, res, next) {
    // do logging
    console.log('Something is happening.');
    console.log('Today is:', Date())
    next();
});

//test route to make sure everything is working (accessed at GET http://localhost:5000/DNZ/)
router.get('/', function(req, res) {
    res.json({ message: 'Welcome to DNZ API!' });   
});

//on routes that end in /FA
//----------------------------------------------------
router.route('/FA')

    // create a FA (accessed at POST http://localhost:8080/DNZ/FA)
    .post(function(req, res) {
        //console.log(req.body);
        //console.log(req.body.params);
        //res.setHeader('Content-Type', 'application/json')
        res.send(JSON.stringify(req.body));
        /*
        var timestamp = req.body.Timestamp;
        var prognostizierterBetriebswert = req.body.PrognostizierterBetriebswert;
        var posFlexPot = req.body.posFlexPot;
        var negFlexPot = req.body.negFlexPot;
        var leistungsuntergrenze = req.body.Leistungsuntergrenze;
        var leistungsobergrenze = req.body.Leistungsobergrenze;
        var posGesEnergie = req.body.posGesEnergie;
        var negGesEnergie = req.body.negGesEnergie;
        var preissignal = req.body.Preissignal;
        var dummy1 = req.body.Dummy1;
        var dummy2 = req.body.Dummy2;
        var dummy3 = req.body.Dummy3;
    */
        var fa = new FA();
        fa.name = req.body.name;
        console.log("Hier erscheint var fa:", fa);
        //console.log(Dummy1);
        //res.send(JSON.stringify(timestamp));

        // create a new instance of the FA model
        /*
        var fa = new FA({
            Timestamp: timestamp,
            Leistungsuntergrenze: leistungsuntergrenze,
            Leistungsobergrenze:leistungsobergrenze,
            PrognostizierterBetriebswert :prognostizierterBetriebswert,
            posFlexPot: posFlexPot,
            negFlexPot:negFlexPot,  
            posGesEnergie: posGesEnergie,
            negGesEnergie: negGesEnergie,
            Preissignal:preissignal,
            Dummy1: dummy1,
            Dummy2: dummy2,
            Dummy3: dummy3          
        })
        */

        //SAVE the new instance
        fa.save(function(err) {
            if (err) {
                console.log(err);
                res.status(400);
                res.send(err);
        }
        else {
            console.log("debug");
            res.status(200);
            res.json({ message: 'FA created!' });
        }
        });

    })

    // get all the FAs (accessed at GET http://localhost:8080/DNZ/FA)
    .get(function(req, res) {
        FA.find(function(err, fas) {
            if (err)
                res.send(err);

            res.json(fas);
        });
    });

//on routes that end in /FA/:FA_id
//----------------------------------------------------
router.route('/FA/:FA_id')

    // get the bear with that id
    .get(function(req, res) {
        FA.findById(req.params.bear_id, function(err, fa) {
            if (err)
                res.send(err);
            res.json(fa);
        });
    })

    // update the bear with this id
    .put(function(req, res) {
        FA.findById(req.params.FA_id, function(err, fa) {

            if (err)
                res.send(fa);

            //bear.name = req.body.name;
            /*
            FA.save(function(err) {
                if (err)
                    res.send(err);

                res.json({ message: 'FA updated!' });
            });
            */
        });
    })

    /*
    // delete the bear with this id
    .delete(function(req, res) {
        FA.remove({
            _id: req.params.bear_id
        }, function(err, FA) {
            if (err)
                res.send(err);

            res.json({ message: 'Successfully deleted' });
        });
    });
     */

//REGISTER OUR ROUTES -------------------------------
app.use('/DNZ', router);

//START THE SERVER
//=============================================================================
app.listen(port);
console.log('Magic happens on port ' + port);


/*
// set static directories
app.use(express.static('./dist'));
app.use(cors());

// Define Routes
var index = require('./routes/index');
var users = require('./routes/users');

//Set up routes
routes.init(app)

//run
app.listen(port);*/
console.log('Server started, Listening on port ',  port);

Я использовал «шаблон» из урока Bear: https://scotch.io/tutorials/build-a-restful-api-using-node-and-express-4 проблема здесь уже в том, что нет сообщения: «Соединение с БД живо». Тем не менее, в уроке медведя (чей код я использовал здесь), соединение с БД построено, и я могу вставить документы медведя в базу данных. Однако здесь это не работает ...

и это моя модель схемы FA от FA.js:

var mongoose = require("mongoose");
var Schema = mongoose.Schema;


var FASchema = new Schema({
    Timestamp: Date,
    PrognostizierterBetriebswert: Number,
    posFlexPot: Number,
    negFlexPot: Number,
    Leistungsuntergrenze: Number,
    Leistungsobergrenze: Number,
    posGesEnergie: Number,
    negGesEnergie: Number,
    Preissignal: Number,
    Dummy1: Schema.Types.Mixed,
    Dummy2: Schema.Types.Mixed,
    Dummy3: Schema.Types.Mixed
    //same: Dummy: {}

});

//var FASchema = new Schema({name: String});

module.exports = mongoose.model("FA", FASchema, 'FA');

console.log("FA wird ausgeführt!");

Кто-нибудь понял, почему не создается соединение с БД?

1 Ответ

0 голосов
/ 15 мая 2018

при тестировании вашего кода выдается ошибка (невозможно установить заголовки после их отправки). Вы можете удалить res.send(JSON.stringify(req.body)); и перезапустить службу

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...