【问题标题】:Node express: 404 on some routes but not others节点快递:在某些路线上是 404,但在其他路线上不是
【发布时间】:2015-07-02 19:02:51
【问题描述】:

所以我有一个问题,我的一些 express.js (v3.2.0) 路由返回 404 状态代码,而其他路由则没有。我无法弄清楚为什么有些路线工作正常而其他路线没有解决。任何帮助将不胜感激。

server.js:

//npm packages
var express = require('express')
  , app = express()
  , server = require('http').createServer(app)
  ;
if(process.env.NODE_ENV == 'production') require('newrelic');

//local resources
init = require('./lib/init');
ctrl = require('./lib/ctrl')

//external async resources (global variables)
init.setup(function(){

  //configure express
  _util.configExpress(__dirname, app, express);

  // create a new AI classifier
  //
  // Arguments
  // ---------
  //    modelType   - (path param) ID of the classifier
  //    modelParams - (body) JSON containing to configure the model
  //
  // Returns
  // -------
  //    200 - ID of created classifier
  //    400 - Error during creation
  app.get('/clf/create/:modelType', _util.auth(express.basicAuth), function(req, res) {
    var modelParams = req.body ? req.body : {};
    var modelType = req.params.modelType;
    ctrl.clfCreate(modelType, modelParams, function(err, result) {
      if(err) {
        // at this point, assume bad request
        res.status(400);
        res.json({"err": err.message});
      } else {
        // if success, return classifier ID
        res.json({"id": result});
      }
      res.end();
    });
  });

  // [Unrelated endpoints...]

  //handle resource update data from io server
  app.all('/:clientId/:projectId/train', _util.auth(express.basicAuth), function (req, res){
    ctrl.trainer(req.params.clientId, req.params.projectId, function(err, result){/*res.json(result);*/});
    res.end();
  });

  // [Unrelated endpoints...]

  //listen on app port
  var port;
  var expr = _env.name == 'prod' ? port = process.env.PORT : port = _env.app.ai.port;
  server.listen(port);
  console.log('Listening to: '+port);
});

_util.configExpress:

self.configExpress = function(dirname, app, express){                                                                                                                                                                                        
  app.configure(function() {                                                                                             
    //setup jade                                                                                                         
    app.set('views', dirname+'/views')                                                                                   
    app.set('view engine', 'jade')                                                                                       
    //setup friendly console logging                                                                                     
    app.use(express.logger('dev'))                                                                                       
    //use body parser for handling http post                                                                             
    app.use(express.bodyParser());                                                                                       
    //define static file server                                                                                          
    app.use(express.static(dirname+'/'+_env.assets));                                                                    
  });                                                                                                                    
} 

但是当我测试端点时:

$ curl -vv --user bst:bst localhost:3002/clf/create/bnn
*   Trying ::1...
* Connected to localhost (::1) port 3002 (#0)
* Server auth using Basic with user 'bst'
> GET /clf/create/bnn HTTP/1.1
> Host: localhost:3002
> Authorization: Basic YnN0OmJzdA==
> User-Agent: curl/7.43.0
> Accept: */*
> 
< HTTP/1.1 404 Not Found
< X-Powered-By: Express
< Content-Type: text/plain
< Content-Length: 9
< Date: Thu, 02 Jul 2015 18:54:32 GMT
< Connection: keep-alive
< 
* Connection #0 to host localhost left intact
Not Found%  

$ -vv --user bst:bst localhost:3002/bst/drone/train
*   Trying ::1...
* Connected to localhost (::1) port 3002 (#0)
* Server auth using Basic with user 'bst'
> GET /bst/drone/train HTTP/1.1
> Host: localhost:3002
> Authorization: Basic YnN0OmJzdA==
> User-Agent: curl/7.43.0
> Accept: */*
> 
< HTTP/1.1 200 OK
< X-Powered-By: Express
< Date: Thu, 02 Jul 2015 18:54:45 GMT
< Connection: keep-alive
< Transfer-Encoding: chunked
< 
* Connection #0 to host localhost left intact
➜  reporting git:(feature/ai-train-api) ✗ 

【问题讨论】:

    标签: node.js express routing


    【解决方案1】:

    您使用的是 express 版本 3,您正在尝试使用类似版本 4 的用户路由参数。

    req.params 是一个数组而不是版本 3 中的对象

    试试看here

    代码示例

    试试这个我想是因为var modelType 未定义,所以您的 ctrl,clfCreate() 函数无法发送响应。在另一个端点中,res.end() 超出了 ctrl 函数的范围

    app.get('/clf/create/:modelType', _util.auth(express.basicAuth), function(req, res) {
        var modelParams = req.body ? req.body : {};
        var modelType = req.params[0];
        ctrl.clfCreate(modelType, modelParams, function(err, result) {
          if(err) {
            // at this point, assume bad request
            res.status(400);
            res.json({"err": err.message});
          } else {
            // if success, return classifier ID
            res.json({"id": result});
          }
          res.end();
        });
      });
    

    【讨论】:

    • 很遗憾,这并没有解决问题。我按照惯例使用 v4 样式,因为团队中的另一个开发人员编写了原始文件并成功使用了它。我不知道是什么黑魔法允许这样做的,但是如果您看到我发布的代码,成功运行的函数也会以这种方式访问​​ req.params 。 编辑: 即使我将第二个端点更改为在内部回调中包含 res.end(),问题仍然存在。
    • 好的,我明白了,很高兴你能测试它。生病再看看,看看我是否能找到问题。您是否尝试过仅发送字符串响应以进行测试? res.send('success');?
    • 尝试在 /clf/create/:modelType 上使用 app.all() 而不是 get()?
    • 不幸的是,这两个方面都没有运气。即使有这个 pastebin.com/dCswM1Qq 。看起来这纯粹是一个路由问题......
    • 将此标记为答案,因为解决方案最终升级为 express v4。也许这是他们身边的一个老错误。
    猜你喜欢
    • 1970-01-01
    • 2016-07-23
    • 2021-01-20
    • 2022-11-03
    • 1970-01-01
    • 2017-10-01
    • 2022-11-18
    • 1970-01-01
    • 2018-01-12
    相关资源
    最近更新 更多