我正在尝试使用“Amplifyjs”来处理AJAX请求,就像John Papa在他的Pluralsight课程中一样,但我在身份验证方面遇到了问题。
我正在使用表单身份验证。一切正常。
我的问题来自未经身份验证的请求。我找不到一种方法让“amplifyjs”回复错误函数http代码(401,403 ...)来区分失败的请求,因为它们没有通过因未满足业务逻辑而失败的请求进行身份验证。
请求示例为:
amplify.request.define("products", "ajax", {
url: "/api/Products",
datatype: "json",
type: "GET"
});
amplify.request({
resourceId: "products",
success: callbacks.success,
error: function (datos, status) {
//somecode
}
});
谢谢。
答案 0 :(得分:6)
如果您想要XHR对象并将其传递,则可以创建解码器。它将包含您可能需要的错误代码和其他信息。
amplify.request.define("products", "ajax", {
url: "http://httpstat.us/401",
datatype: "json",
type: "GET",
decoder: function ( data, status, xhr, success, error ) {
if ( status === "success" ) {
success( data, xhr );
} else if ( status === "fail" || status === "error" ) {
error( status, xhr );
} else {
error( status, xhr );
}
}
});
amplify.request({
resourceId: "products",
success: function(data, status) {
console.log(data, status);
},
error: function(status, xhr) {
console.log(status, xhr);
}
});
您可以通过查看此http://jsfiddle.net/fWkhM/
来测试上述代码答案 1 :(得分:2)
感谢您的回答。
最后,正如我所见,没有人回答我,我做了类似于你的建议:
var decoder = function (data, status, xhr, success, error) {
if (status === "success") {
success(data, status);
} else if (status === "fail" || status === "error") {
try {
if (xhr.status === 401) {
status = "NotAuthorized";
}
error(JSON.parse(xhr.responseText), status);
} catch (er) {
error(xhr.responseText, status);
}
}
};
修改默认解码器后:
amplify.request.decoders._default = decoders.HeladeriaDecoder;
在错误回调中,我管理了返回的状态。
error: function (response, status) {
if (status === "NotAuthorized") {
logger.error(config.toasts.errorNotAuthenticated);
} else {
logger.error(config.toasts.errorSavingData);
}
//more code...
}