Amplifyjs和状态代码

时间:2012-10-25 17:06:26

标签: javascript ajax amplifyjs

我正在尝试使用“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
                           }
                });

谢谢。

2 个答案:

答案 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...
}