MissingSchemaError: Схема не была зарегистрирована для модели "Магазин" - PullRequest
0 голосов
/ 14 декабря 2018

Я использую учебник Wes Boss Node.js и столкнулся с рядом проблем с ошибками схемы.

Моя база данных в настоящее время работает на mLab и MongoDB Compass.Вчера было хорошо, когда я ушел на работу, и я только что успешно добавил свой первый бит данных в БД.Этим утром я продолжаю с того места, на котором остановился, и все внезапно ломается.

Я попытался удалить каталог node_modules, запустив npm cache clean и npm install.Я попытался изменить порядок зависимостей.Я подумал, что это может быть связано с перезапуском соединения, поэтому я закрыл соединение, вышел из Compass, заново открыл и снова подключился к БД.Я попытался удалить таблицу "сессий" и заново подключиться.Не повезло.

Я попытался вставить адрес сервера базы данных в адресную строку моего браузера и получил сообщение об успешном подключении.

Ошибка:

MissingSchemaError: Schema hasn't been registered for model "Store". Use mongoose.model(name, schema) 
at MissingSchemaError (C:\Users\Misha\Desktop\dang-thats-delicious\node_modules\mongoose\lib\error\missingSchema.js:20:11)

app.js:

const express = require('express');
const session = require('express-session');
const mongoose = require('mongoose');
const MongoStore = require('connect-mongo')(session);
const path = require('path');
const cookieParser = require('cookie-parser');
const bodyParser = require('body-parser');
const passport = require('passport');
const promisify = require('es6-promisify');
const flash = require('connect-flash');
const expressValidator = require('express-validator');
const routes = require('./routes/index');
const helpers = require('./helpers');
const errorHandlers = require('./handlers/errorHandlers');

const app = express();

app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'pug');

app.use(express.static(path.join(__dirname, 'public')));

app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));

app.use(expressValidator());

app.use(cookieParser());

app.use(session({
  secret: process.env.SECRET,
  key: process.env.KEY,
  resave: false,
  saveUninitialized: false,
  store: new MongoStore({ mongooseConnection: mongoose.connection })
}));

app.use(passport.initialize());
app.use(passport.session());

app.use(flash());

app.use((req, res, next) => {
  res.locals.h = helpers;
  res.locals.flashes = req.flash();
  res.locals.user = req.user || null;
  res.locals.currentPath = req.path;
  next();
});

app.use((req, res, next) => {
  req.login = promisify(req.login, req);
  next();
});

app.use('/', routes);

app.use(errorHandlers.notFound);

app.use(errorHandlers.flashValidationErrors);

if (app.get('env') === 'development') {
  app.use(errorHandlers.developmentErrors);
}

app.use(errorHandlers.productionErrors);

module.exports = app;

index.js:

const express = require('express');
const router = express.Router();
const storeController = require('../controllers/storeController');
const { catchErrors } = require('../handlers/errorHandlers');

router.get('/', storeController.homePage);
router.get('/add', storeController.addStore);
router.post('/add', catchErrors(storeController.createStore));

module.exports = router;

start.js:

require('./models/Store');
const mongoose = require('mongoose');
const Store = mongoose.model('Store');

require('dotenv').config({ path: 'variables.env' });

mongoose.connect(process.env.DATABASE);
mongoose.Promise = global.Promise;
mongoose.connection.on('error', (err) => {
  console.error(`${err.message}`);
});

require('./models/Store');

const app = require('./app');
app.set('port', process.env.PORT || 7777);
const server = app.listen(app.get('port'), () => {
  console.log(`Express running → PORT ${server.address().port}`);
});

1 Ответ

0 голосов
/ 14 декабря 2018

Ну, я думаю, что решил свою проблему.Моему storeController.js файлу нужно require('../models/Store'); вверху, справа внизу const mongoose = require('mongoose');

Однако теперь я получаю еще одну ошибку и считаю, что это связано с удалением моих сохраненных сеансов из БД:

express-session deprecated req.secret; provide secret option at app.js:38:9

Попытка воссоздать БД и посмотреть, что произойдет.

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