5

我有一个 AngularJS、JS、JQ、HTML5、CSS3 网络应用程序。应该向我们项目的 REST API 发送不同的 HTTP 方法并对其进行操作。它与Restlet(以前的 Dev HTTP Client)的 DHC 具有相似的行为。每个请求都会返回一个状态码,如 200、201、404、500 等,然后显示给用户。

现在我想要的不仅是显示响应代码,而且还像这样显示它的描述:

404 Not Found201 Created

我收到来自 Angular 的这样的回复:

$http(config).success(function (data, status, headers, config) {//some logic}

有谁知道这是否可以使用AngularJS?

4

5 回答 5

12

好吧,我最终得到了以下解决方案:

我创建了一个常量变量并列出了所有 HTTP 代码及其描述(您可以将它们复制到您自己的程序中):

常量.js:

var HTTP_STATUS_CODES = {
        'CODE_200' : 'OK',
        'CODE_201' : 'Created',
        'CODE_202' : 'Accepted',
        'CODE_203' : 'Non-Authoritative Information',
        'CODE_204' : 'No Content',
        'CODE_205' : 'Reset Content',
        'CODE_206' : 'Partial Content',
        'CODE_300' : 'Multiple Choices',
        'CODE_301' : 'Moved Permanently',
        'CODE_302' : 'Found',
        'CODE_303' : 'See Other',
        'CODE_304' : 'Not Modified',
        'CODE_305' : 'Use Proxy',
        'CODE_307' : 'Temporary Redirect',
        'CODE_400' : 'Bad Request',
        'CODE_401' : 'Unauthorized',
        'CODE_402' : 'Payment Required',
        'CODE_403' : 'Forbidden',
        'CODE_404' : 'Not Found',
        'CODE_405' : 'Method Not Allowed',
        'CODE_406' : 'Not Acceptable',
        'CODE_407' : 'Proxy Authentication Required',
        'CODE_408' : 'Request Timeout',
        'CODE_409' : 'Conflict',
        'CODE_410' : 'Gone',
        'CODE_411' : 'Length Required',
        'CODE_412' : 'Precondition Failed',
        'CODE_413' : 'Request Entity Too Large',
        'CODE_414' : 'Request-URI Too Long',
        'CODE_415' : 'Unsupported Media Type',
        'CODE_416' : 'Requested Range Not Satisfiable',
        'CODE_417' : 'Expectation Failed',
        'CODE_500' : 'Internal Server Error',
        'CODE_501' : 'Not Implemented',
        'CODE_502' : 'Bad Gateway',
        'CODE_503' : 'Service Unavailable',
        'CODE_504' : 'Gateway Timeout',
        'CODE_505' : 'HTTP Version Not Supported'
    };

然后在我的 AngularJS 控制器中,当我收到来自我的状态时,$http我只需调用此函数,它将状态代码消息的值设置为模型:

setResponseCodeDescr = function(responseCode) {

var responseCodeConstant = 'CODE_'.concat(responseCode);

if (HTTP_STATUS_CODES[responseCodeConstant]){
    $rootScope.response.description = HTTP_STATUS_CODES[responseCodeConstant];
} else {
    $rootScope.response.description = "";
}

}

就这样 :)

于 2014-04-10T13:44:10.343 回答
2

使用 Angular 进行调用时,您会返回状态码,其中包含status您在成功函数中显示的变量。以我所见过的任何方式,Angular 似乎都没有将文本返回给您。

您可以使用 switch 语句来显示与代码一起出现的消息,但显然对于所有可能的代码来说,这可能是一个很长的 switch 语句。您还可以将要显示的消息作为数据的一部分返回,这只不过是将工作放在后端而不是前端。

至于从代码到消息的转换,我建议将其放在指令(或过滤器)中,并在您的应用程序中重用它以获取代码并返回消息以与它一起显示在 UI 中。

于 2014-04-10T13:16:55.657 回答
1

我会按照“amenoire/Jason C”的建议进行制作,但是常量

var HTTP_STATUS_CODES = {
        '200' : 'OK',
        '201' : 'Created'
...
        '505' : 'HTTP Version Not Supported'
};

写了没有前缀“CODE_”并将它们称为

var s =  HTTP_STATUS_CODES[xmlhttp.status]
if (!(s && s.length > 0)) s = 'look at https://developer.mozilla.org/en-US/docs/Web/HTTP/Status'
于 2017-03-05T12:40:27.583 回答
0

如果我没记错的话,您仍然可以使用 jQuery ajax 进行调用,并使用 $.ajaxSetup 设置响应,如下所示:

$.ajaxSetup({
    type: "GET",
    dataType: "jsonp",
    error: function(xhr, exception){
        if( xhr.status === 0)
            alert('Error : ' + xhr.status + 'You are not connected.');
        else if( xhr.status == "201")
            alert('Error : ' + xhr.status + '\nServer error.');
        else if( xhr.status == "404")
            alert('Error : ' + xhr.status + '\nPage note found');
        else if( xhr.status == "500")
             alert('Internal Server Error [500].');
        else if (exception === 'parsererror') 
            alert('Error : ' + xhr.status + '\nImpossible to parse result.');
        else if (exception === 'timeout')
            alert('Error : ' + xhr.status + '\nRequest timeout.');
        else
            alert('Error .\n' + xhr.responseText);
    }
});
于 2014-04-10T12:15:51.707 回答
0

不过,从技术上获取代码似乎很容易,“只需附加响应的内置属性即可获得描述”。

实际上,文档中对此进行了解释,一旦您获得了响应及其属性,您就可以对它做任何事情。另一种方法是创建一个常数,但我认为我们通常不需要这么多。

$http({
    method: 'GET',
    url: '/someUrl'
}).then(function successCallback(response) {
    var status = response.status;
    console.log(status); // gives the status 200/401
    var statusText = response. statusText;
    console.log(status); // HTTP status text of the response
}, function errorCallback(response) {

});
于 2015-10-23T00:56:48.560 回答