错误回调后重新调用Backbone.Sync方法
Re-call Backbone.Sync method after error callback
我正在开发一个应用程序,如果我们的Bearer令牌已过期,我们将从服务器返回401。我们想调用一个端点/api/newToken
,并将新的承载令牌设置为cookie(稍后将添加到头中),然后重新调用发生错误时调用的URL(401状态)。
我们覆盖了主干同步方法
var sync_mixin = {
// `preSync` is a useful hook from which events can be published,
// and options / model may be modified.
preSync: function (method, model, options) {},
// override sync to:
// - call preSync first
// - because tastypie and backbone disagree on whether delete should have trailing slash
sync: function (method, model, options) {
model.preSync(method, model, options);
options = options || {};
options.headers = getAuthHeaders()
// Add trailing slash to backbone model views
var _url = _.isFunction(model.url) ? model.url() : model.url;
// Missing the case where there is a query string on a detail view here: /v7.0/<resource>/<id>?key=val
_url += _url.charAt(_url.length - 1) == '/' || _url.indexOf('?') != -1 ? '' : '/';
options = _.extend(options, {
url: _url,
model: model
});
if (method.toLowerCase() === 'delete') {
if (!options.url) {
options.url = _.result(model, 'url').replace(/'/$/, "") + '/';
}
}
return Backbone.sync.apply(this, arguments);
}
};
Backbone.Model = Backbone.Model.extend(sync_mixin);
理想情况下,我希望一次性处理错误(而不是在每个模型文件中)。我试图实现的是,当我在sync上得到错误时,调用api端点获取新的令牌,将其设置为cookie,并用新的cookie作为令牌重新调用原始sync方法。以下是我尝试过的,但我遇到了最大的调用堆栈错误。我在上面的同步功能中添加了这个代码
options.error = function(xhr, status, thrown) {
if(xhr.status === 401 || xhr.status === 403){
$.cookies.set("auth-token", '6fe36b69cdac549339850a5aa2f148b470dc2e0e');
Backbone.sync.apply(this.model, arguments);
}
}
关于如何解决这个问题有什么建议吗?我可以得到任何其他需要的东西。
我完成了这项工作。Tte max调用堆栈错误是由于我意外地将请求添加回进行递归调用的选项。
这是我的代码,允许调用同步
var errorHandler = options.error;
options.error = function(xhr) {
var errorHandlerArgs = arguments;
if ((xhr.status === 401 || xhr.status === 0) && $this.ajaxTried < 3) {
$this.ajaxTried++;
//call refresh_bearer/ URL
$.ajax({
url: "/api/refresh_bearer/",
headers: args[2].headers
}).done(function (data) {
args[2].headers = getAuthHeaders()
Backbone.sync.apply($this, args);
});
} else {
$this.ajaxTried = 0;
errorHandler.apply($this, errorHandlerArgs);
}
};
相关文章:
- 点击功能没有'ajax调用动态元素(Backbone)后无法工作
- Backbone fetch中的Ajax在fetch调用退出后完成,因此fetch调用中没有成功/失败事件
- Backbone.js ListenToOnce被调用两次
- Backbone应用程序中的多个jQueryAjax调用会混淆数据
- 不能从 Backbone.View 的方法调用 Backbone.collection 的方法,其中包含 require
- Backbone.js的新手,如何从html按钮和链接调用函数
- 从Backbone中的另一个视图调用新视图
- fetch()不调用其Success和Error回调函数(backbone.js)
- 将对象设置为Backbone.js模型,而不必调用“;set()"在每一处房产上
- Backbone.js在填充集合后调用render
- Backbone js视图渲染点击方法未调用[Very Basic]
- 任何理由从外部调用Backbone.View.render
- 使用 Backbone LocalStorage 并仍调用服务器
- 调用 Backbone 内部的外部函数.js的视图初始化方法
- BackBone js-如何在进行AJAX调用时设置contentType
- 如何在完成多个异步调用后延迟Backbone中的调用
- Backbone JS Model Fetch在Fiddler中返回200,但调用错误方法
- 如何手动调用Backbone.js视图's方法
- 错误回调后重新调用Backbone.Sync方法
- Require/Backbone:在调用Backbone时重载Backbone