【问题标题】:How to setup express routes separate from main file?如何设置与主文件分开的快速路线?
【发布时间】:2023-10-08 05:25:01
【问题描述】:

我想按照下面的文件结构将我的 rputes 与主要的app.js 分开我已经尝试过返回 404 的api/user/post api,知道如何使用下面的文件结构来解决这个问题吗?

./app.js

var express        = require('express');
var app            = express();
var bodyParser     = require('body-parser');
var db = require('./config/db');
var port = process.env.PORT || 8080;  
app.use(require('./app/routes'));
app.use(bodyParser.json({ type: 'application/vnd.api+json' })); 
app.use(bodyParser.urlencoded({ extended: true })); 
app.use(methodOverride('X-HTTP-Method-Override')); 
app.use(express.static(__dirname + '/public')); 
function startServer() {
  server.listen(port, function() {
    console.log('Express server listening on %d, in %s mode', port, app.get('env'));
  });
}               
setImmediate(startServer);

// expose app           
exports = module.exports = app; 

./app/routes.js

module.exports = function(app) {

    app.use('/api/user', require('./api/user'));
    app.route('*')
        .get(function(req, res) {
            // res.sendFile('./public/views/index.html');
            res.sendfile('./public/views/index.html');
        });
};

./app/api/user/index.js

var express = require('express');
var controller = require('./user.controller');

var router = express.Router();

router.get('/', controller.index);
router.post('/',controller.create);


module.exports = router;

错误

angular.js: 12410 POST http: //localhost:8080/api/user 404 (Not Found)
    (anonymous) @ angular.js: 12410
p @ angular.js: 12155(anonymous) @ angular.js: 11908(anonymous) @ angular.js: 16648
$eval @ angular.js: 17972
$digest @ angular.js: 17786
$apply @ angular.js: 18080(anonymous) @ angular.js: 26749
cg @ angular.js: 3613
d @ angular.js: 3601
angular.js: 14328 Possibly unhandled rejection: {
    "data": "Cannot POST /api/user\n",
    "status": 404,
    "config": {
        "method": "POST",
        "transformRequest": [null],
        "transformResponse": [null],
        "jsonpCallbackParam": "callback",
        "url": "/api/user",
        "data": {
            "firstName": "John",
            "lastName": "Zhang"
        },
        "headers": {
            "Accept": "application/json, text/plain, */*",
            "Content-Type": "application/json;charset=utf-8"
        }
    },
    "statusText": "Not Found"
}

【问题讨论】:

    标签: javascript node.js express middleware


    【解决方案1】:

    顺便说一句,你在index.js中定义了路由并在routes.js中挂载,它会为/api/user提供404,因为当它在index.js中搜索/时,它只会找到/api/users只有/api/user/api/users 可以访问。

    您可以尝试将userrouter 挂载到/api/user 并可以在index.js 中定义/ 路由

    ./app/api/user/index.js

    var express = require('express');
    var controller = require('./user.controller');
    
    var router = express.Router();
    
    //GET /api/user
    router.get('/', controller.index);
    
    //POST /api/user
    router.post('/',controller.create);
    
    module.exports = router;
    

    ./app/routes.js

    module.exports = function(app) {
    
      //ANY /api/*
      app.use('/api/user', require('./api/user'));
    
      app.route('*')
        .get(function(req, res) {
            // res.sendFile('./public/views/index.html');
            res.sendfile('./public/views/index.html');
        });
      };
    

    希望对你有帮助。

    更新

    您的代码中还有另一个问题。在您的 app.js 中,您定义了 app.use(require('./app/routes'));routes.jsfunction(app)

    将该行更改为

    require('./app/routes')(app);
    

    并在app.use(express.static(__dirname + '/public'));之后添加该行

    【讨论】:

    • 我根据您的回答进行了更改,我得到了我已更新的错误,请看一下。看起来我们需要修复app.js
    【解决方案2】:

    您的问题与您的需求/导入有关。首先尝试使用 app.js 文件中的正常路由访问

    【讨论】:

    • 感谢您的回答!你能花时间提供一个例子吗?这将使您的答案变得更好。