Backbone.js不会发布到指定的URL

问题描述 投票:0回答:3

我有一个与此生成器https://github.com/yeoman/generator-backbone一起运行的Backbone.js应用程序。我需要向在不同服务器和域上运行的服务发出POST请求。在我的模型上,我有以下内容:

urlRoot: 'https://custom.com/',

saveData: function(params) {
  this.set(params);
  if(this.isValid()) {
    this.save(null, {
      url: 'api/v1/data',
      success: function(model, response, options) {
        // success
      },
      error: function(model, response, options) {
        // error
      }
    });
  }
}

[当我尝试发布数据时,它将数据发布到http://localhost:9000/api/v1/data。知道为什么Backbone选择POST而不是我提供的设置[https://custom.com/api/v1/data)到正在运行的服务器吗?

在我的服务器上,我在NodeJS上运行Restify(为了测试目的,我允许来自任何客户端的源)。这是我设置CORS的方法:

// Setup CORS
api.use(function(req, res, next) {
  res.header('Access-Control-Allow-Origin', '*');
  res.header('Access-Control-Allow-Methods', 'GET,POST,PUT,DELETE, OPTIONS');
  res.header('Access-Control-Allow-Headers', 'X-Requested-With');
  return next();
});

我怀疑服务器是否存在问题,因为客户端甚至无法访问它,因为指定的URL会自动映射到http://localhost:9000/api/v1/data而不是https://custom.com/api/v1/data

更新:如果我使用jQuery(不使用Backbone的API)“手动”执行,则可以正常工作:

saveData: function() {
  $.ajax({
     type: 'POST',
     data: this.toJSON(),
     url: 'https://custom.com/api/v1/data'
  })
  .success(function() {
    // success
  })
  .fail(function() {
    // fail
  });
}

反正有使用Backbone的API进行此操作吗?

javascript backbone.js
3个回答
1
投票

url作为选项传递给Backbone.Model.prototype.save将绕过url生成逻辑(即urlRoot),并假定url选项为完整路径(如果未发布到当前域,则包括该域)。

您应该将urlRoot设置为实体的路径(或后端平台可以调用的任何路径),因此在您的情况下应为:

var MyModel = Backbone.Model.extend({
    urlRoot: 'https://custom.com/api/v1/data'
});
var myModel = new MyModel();
myModel.save(); // POST https://custom.com/api/v1/data
// Assuming that returns an id of '123';
myModel.save(); // PUT https://custom.com/api/v1/data/123
myModel.destroy(); // DELETE https://custom.com/api/v1/data/123

如果您的服务器未设置为处理骨干风格RESTful端点,那么您可能只想覆盖Backbone.Model.prototype.url而不是urlRoot


1
投票

如果只想测试对服务器的呼叫,则可以下载Chrome扩展程序。它将允许您拨打其他域的电话。此处:https://chrome.google.com/webstore/detail/allow-control-allow-origi/nlfbmbojpeacfghkpbjhddihlkkiljbi


0
投票

无法通过浏览器将请求发布到其他域。更好的方法是在服务器中设置一些重定向规则。

© www.soinside.com 2019 - 2024. All rights reserved.