如何使用$ resource读取响应头?

时间:2014-04-10 22:32:42

标签: angularjs http-headers response-headers

我使用$ resource从我的RESTful服务中获取数据,我需要阅读响应标头才能获得X-Page'和' X-Total-Pages'分页的价值。

示例:

Access-Control-Max-Age:1728000
Cache-Control:max-age=0, private, must-revalidate
Connection:Keep-Alive
Content-Length:2637
Content-Type:application/json
Date:Thu, 10 Apr 2014 16:53:01 GMT
Server:WEBrick/1.3.1 (Ruby/2.1.1/2014-02-24)
Vary:Origin
X-Page:1
X-Per-Page:10
X-Total:17
X-Total-Pages:2

但我无法从服务器获得完整的标头。

这是返回的标题: enter image description here

这是服务器的标头: enter image description here

这是我的代码:

.factory('TestAPI', ['$resource',
        function ($resource) {
            return $resource("http://ip.jsontest.com/?callback=showIP", {}, {
                query: {
                    method: 'GET'
                }
            });
        }])

TestAPI.query({}, function (value, responseHeaders) {
                console.log(responseHeaders());
            }, function (response) {
                console.log(response);
 });

2 个答案:

答案 0 :(得分:9)

在您的回复标题中,您必须添加以下标题:

Access-Control-Expose-Headers: X-Total-Pages, X-Page

通过这种方式,浏览器能够将您的海关标题公开显示为有角度的。

答案 1 :(得分:0)

做完@nancoder所说的

您可以通过在$ resource中添加拦截器来读取标头。

看起来像这样

.factory('TestAPI', ['$resource',
        function ($resource) {
            return $resource("http://ip.jsontest.com/?callback=showIP", {}, {
                query: {
                    method: 'GET',
                    interceptor: {
                        response: function (resp) {
                            console.log(resp.headers("X-Total-Pages"));
                            console.log(resp.headers("X-Page"));
                            return resp.resource;
                        }
                    }
                }
            });
        }])