Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/node.js/33.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
Javascript ';路由器。获取';vs';router.route.get';在express.js中_Javascript_Node.js_Express - Fatal编程技术网

Javascript ';路由器。获取';vs';router.route.get';在express.js中

Javascript ';路由器。获取';vs';router.route.get';在express.js中,javascript,node.js,express,Javascript,Node.js,Express,我刚刚开始学习MEAN stack,并学习了教程中的文件api.js和auth.js 在api.js中,我有下面的路由结构 var express = require('express'); var router = express.Router(); //Used for routes that must be authenticated. function isAuthenticated (req, res, next) { // i

我刚刚开始学习MEAN stack,并学习了教程中的文件api.js和auth.js

在api.js中,我有下面的路由结构

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

    //Used for routes that must be authenticated.
    function isAuthenticated (req, res, next) {
        // if user is authenticated in the session, call the next() to call the next request handler 
        // Passport adds this method to request object. A middleware is allowed to add properties to
        // request and response objects

        //allow all get request methods
        if(req.method === "GET"){
        console.log('in console');
            return next();
        }
        if (req.isAuthenticated()){
            return next();
        }

        // if the user is not authenticated then redirect him to the login page
        return res.redirect('/#login');
    };

    //Register the authentication middleware
    router.use('/posts', isAuthenticated);
    router.route('/posts')

    .get(function(req,res){
    res.send({message:'TODO: return all posts'});
    })

    .post(function(req,res){
    res.send({message:'TODO: create new post'});
    });

    router.route('/posts/:id')

    .get(function(req,res){
    res.send({message:'TODO: return post with ID ' + req.params.id});
    })

    .put(function(req,res){
    res.send({message:'TODO: modify post with ID ' + req.params.id});
    })

    .delete(function(req,res){
    res.send({message:'TODO: delete post with ID ' + req.params.id});
    });
    module.exports = router;
var express = require('express');
var router = express.Router();

module.exports = function(passport){

    //sends successful login state back to angular
    router.get('/success', function(req, res){
        res.send({state: 'success', user: req.user ? req.user : null});
    });

    //sends failure login state back to angular
    router.get('/failure', function(req, res){
        res.send({state: 'failure', user: null, message: "Invalid username or password"});
    });

    //log in
    router.post('/login', passport.authenticate('login', {
        successRedirect: '/auth/success',
        failureRedirect: '/auth/failure'
    }));

    //sign up
    router.post('/signup', passport.authenticate('signup', {
        successRedirect: '/auth/success',
        failureRedirect: '/auth/failure'
    }));

    //log out
    router.get('/signout', function(req, res) {
        req.logout();
        res.redirect('/');
    });

        return router;    
}
在auth.js中,我有下面的路由结构

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

    //Used for routes that must be authenticated.
    function isAuthenticated (req, res, next) {
        // if user is authenticated in the session, call the next() to call the next request handler 
        // Passport adds this method to request object. A middleware is allowed to add properties to
        // request and response objects

        //allow all get request methods
        if(req.method === "GET"){
        console.log('in console');
            return next();
        }
        if (req.isAuthenticated()){
            return next();
        }

        // if the user is not authenticated then redirect him to the login page
        return res.redirect('/#login');
    };

    //Register the authentication middleware
    router.use('/posts', isAuthenticated);
    router.route('/posts')

    .get(function(req,res){
    res.send({message:'TODO: return all posts'});
    })

    .post(function(req,res){
    res.send({message:'TODO: create new post'});
    });

    router.route('/posts/:id')

    .get(function(req,res){
    res.send({message:'TODO: return post with ID ' + req.params.id});
    })

    .put(function(req,res){
    res.send({message:'TODO: modify post with ID ' + req.params.id});
    })

    .delete(function(req,res){
    res.send({message:'TODO: delete post with ID ' + req.params.id});
    });
    module.exports = router;
var express = require('express');
var router = express.Router();

module.exports = function(passport){

    //sends successful login state back to angular
    router.get('/success', function(req, res){
        res.send({state: 'success', user: req.user ? req.user : null});
    });

    //sends failure login state back to angular
    router.get('/failure', function(req, res){
        res.send({state: 'failure', user: null, message: "Invalid username or password"});
    });

    //log in
    router.post('/login', passport.authenticate('login', {
        successRedirect: '/auth/success',
        failureRedirect: '/auth/failure'
    }));

    //sign up
    router.post('/signup', passport.authenticate('signup', {
        successRedirect: '/auth/success',
        failureRedirect: '/auth/failure'
    }));

    //log out
    router.get('/signout', function(req, res) {
        req.logout();
        res.redirect('/');
    });

        return router;    
}
上面的代码可以很好地工作,但每当我尝试重写api.js的代码时,比如下面的auth.js结构

module.exports = function(){

router.get('/posts',function(req,res)
{
  res.send({message:'TODO: return all posts'});
});

router.post('/posts',function(req,res)
{
  res.send({message:'TODO: add new post'});
});

router.get('/posts/:id',function(req,res)
{
  res.send({message:'TODO: return post with ID ' + req.params.id});
});

router.put('/posts/:id',function(req,res)
{
  res.send({message:'TODO: edit post with ID ' + req.params.id});
});

router.delete('/posts/:id',function(req,res)
{
  res.send({message:'TODO: delete post with ID ' + req.params.id});
});

return router;
}
这不管用。下面是每当我发出post或get请求时node cmd提示符的屏幕截图。我是否以错误的方式重写代码


您现在在
api.js
中导出一个函数和一个路由器实例。如果您没有相应地更改使用
api.js
的文件,您将挂载一个函数而不是路由器

因此,对于新的
api.js
,您的父文件需要执行以下操作:

var apiRoutes = require('./api')();
app.use('/api', apiRoutes);
var apiRoutes = require('./api');
app.use('/api', apiRoutes);
而不是像:

var apiRoutes = require('./api')();
app.use('/api', apiRoutes);
var apiRoutes = require('./api');
app.use('/api', apiRoutes);