404 при вызове API в Thinkster MEAN Stack Tutorial

Я следую этому руководству Thinkster по созданию сети в стиле Reddit. приложение, использующее MEAN.

В руководстве рассказывается об использовании curl для создания нового сообщения.

C:\root>curl --data "title=test&link=http://test.com" http://localhost:3000/posts

Однако я получаю эту ошибку в ответ:

<h1>Not Found</h1>
<h2>404</h2>
<pre>Error: Not Found
    at C:\root\app.js:30:13
    at Layer.handle [as handle_request] (C:\root\node_modules\express\lib\router\layer.js:95:5)
    at trim_prefix (C:\root\node_modules\express\lib\router\index.js:312:13)
    at C:\root\node_modules\express\lib\router\index.js:280:7
    at Function.process_params (C:\root\node_modules\express\lib\router\index.js:330:12)
    at next (C:\root\node_modules\express\lib\router\index.js:271:10)
    at C:\root\node_modules\express\lib\router\index.js:618:15
    at next (C:\root\node_modules\express\lib\router\index.js:256:14)
    at Function.handle (C:\root\node_modules\express\lib\router\index.js:176:3)
    at router (C:\root\node_modules\express\lib\router\index.js:46:12)</pre>

Я просмотрел эти файлы, но все ссылки просто показывали мне, что происходит с ошибкой...

Вот код

/маршруты/index.js:

var express = require('express');
var router = express.Router();

/* GET home page. */
router.get('/', function(req, res, next) {
  res.render('index', { title: 'Express' });
});

module.exports = router;

var mongoose = require('mongoose');
var Post = mongoose.model('Post');
var Comment = mongoose.model('Comment');

router.get('/posts', function(req, res, next){
    Post.find(function(err,posts){
        if(err){ return next(err); }

        res.json(posts);
    })
})
router.post('/posts', function(req,res,next){
    var post = new Post(req.body);

    post.save(function(err, post){
        if(err){ return next(err); }

        res.json(post);
    })
})

/models/Posts.js:

var mongoose = require('mongoose');

var PostSchema = new mongoose.Schema({
    title: String,
    link: String,
    upvotes: {type: Number, default: 0},
    comments: [{type: mongoose.Schema.Types.ObjectId, ref: 'Comment'}]
});

mongoose.model('Post', PostSchema);

приложение.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 index = require('./routes/index');
var users = require('./routes/users');

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);
app.use('/users', users);

// 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;

var mongoose = require('mongoose');
require('./models/Posts');
require('./models/Comments');

mongoose.connect('mongod:localhost/news');

Я чувствую, что сделал все правильно, за исключением того, что я не был уверен, где разместить дополнительные маршруты в индексном файле маршрутов, а также в app.js. Но мне это кажется незначительным. Я выполнил всю отладку, о которой только мог подумать, но застрял.

Следует также отметить, что это руководство, возможно, не предназначено для использования на компьютере с Windows. Мне пришлось установить curl и сделать несколько других вещей, которые, возможно, не понадобятся на Linux или Mac. Я использую Windows 10.


person Travis Heeter    schedule 30.12.2016    source источник
comment
Я отказываюсь от этого вопроса и удаляю свой ответ, так как понятия не имею, что вызывает вашу проблему. Я бы порекомендовал вам узнать намного больше о том, что на самом деле происходит в вашей программе, а не просто слепо следовать генераторам приложений и руководствам, ничего не зная о том, что они делают или как они работают. Кроме того, когда люди просят код, который запускает ваш сервер (который находится в вашем app.js), не тратьте 19 часов, чтобы наконец предоставить его. Удачи в решении вашей проблемы.   -  person jfriend00    schedule 31.12.2016
comment
@ jfriend00 Я просто пытаюсь заставить работать простой API. Я думал, что смогу научиться, когда пройду этот урок. Как еще я должен изучить этот материал?   -  person Travis Heeter    schedule 31.12.2016
comment
Если вы не знаете, что делает ваш код и как он работает, то вы не будете знать, как исправлять или отлаживать вещи, когда что-то перестает работать. Я лично начал с более простого приложения, созданного вручную, и добавлял элементы по одному, по мере того как я понимал, как они работают и как они подключаются к приложению. Я не начинал с многофайлового приложения, созданного каким-то генератором с маршрутизаторами и базами данных, пока не понял основы маршрутизации запросов в Express. Вы пытались прыгнуть вперед на 10 шагов, не зная, как работает любой из 9 предыдущих.   -  person jfriend00    schedule 31.12.2016
comment
@frlan Извините, я обновлю это. Я просто имел в виду, что папка, из которой я ее запускаю, является корневой папкой сайта. Я работаю в Windows, поэтому не думаю, что root вообще пользователь. Или была другая причина, по которой вы сделали этот комментарий?   -  person Travis Heeter    schedule 03.01.2017
comment
@TravisHeeter Привет! Не могли бы вы проверить: правильно ли обрабатываются ваши маршруты, если вы ПОЛУЧИТЕ их с помощью браузера, и пробовали ли вы вариант RESTful POST с помощью curl -X POST --data ... localhost:3000/сообщений? Кроме того, я предполагаю, что этот сгенерированный app.js мог быть неправильно настроен (из-за его отсутствия в учебнике).   -  person Damaged Organic    schedule 05.01.2017
comment
@KidBinary Я получаю ту же ошибку 404 от localhost: 3000/posts. app.js автоматически настраивается экспресс-генератором. Тем не менее, в руководстве было указано добавить несколько строк чтобы потребовать файлы модели (Posts.js и Comments.js).   -  person Travis Heeter    schedule 05.01.2017


Ответы (1)


Ваш module.exports вызывается преждевременно в routes/index.js. Переместите module.exports = router; в конец файла, перезапустите службу и повторите попытку.

Также есть проблемы с app.js. Смотри ниже:

приложение.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');

// Notice the differences starting here
var app = express();

var mongoose = require('mongoose');

// connect MongoDB
mongoose.connect('mongodb://localhost/news', function(err,db){
    if (!err){
        console.log('Connected to /news!');
    } else{
        console.dir(err); //failed to connect
    }
});

require('./models/Posts');
require('./models/Comments');

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

// 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);
app.use('/users', users);

// 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:

var express = require('express');
var router = express.Router();
var mongoose = require('mongoose');
var Post = mongoose.model('Post');
var Comment = mongoose.model('Comment');

/* GET home page. */
router.get('/', function(req, res, next) {
  res.render('index', { title: 'Express' });
});

router.get('/posts', function(req, res, next){
    Post.find(function(err,posts){
        if(err){ 
            alert(err);
            return next(err); 
        }

        res.json(posts);
    })
})

router.post('/posts', function(req,res,next){
    var post = new Post(req.body);

    post.save(function(err, post){
        if(err){ 
            alert(err);
            return next(err); 
        }

        res.json(post);
    })
})

module.exports = router;
person LostJon    schedule 05.01.2017
comment
Как перезапустить службу — просто закрыть окно cmd, которое я использовал для npm start, и снова запустить его? - person Travis Heeter; 06.01.2017
comment
извините, переработайте, как при остановке вашего экспресс-приложения, и перезапустите после внесения изменений. Так что да, npm start. Если вы хотите, чтобы ваши сервисы сохранялись, я настоятельно рекомендую pm2. - person LostJon; 06.01.2017