15

我需要做一些跨站点脚本。下面的代码块包含jsonp的方法,该方法返回好像失败了,但是当我将其更改为get请求时,我就成功了。我需要能够使用 jsonp 方法成功响应。可以排除以下情况。响应是有效的 json,这个参数在 url ?callback=JSON_CALLBACK 中。这是我从执行 http 请求和执行此代码的代码块中收到的 json。

http响应状态码200

[{"cube":"1" ,"points":"160"},{"cube":"2","points":"690"},{"cube":"3","points":"331"}]

代码块

 var myApp = angular.module('test', []);

    myApp.controller('UserCtrl', function($scope, users) {
        $scope.usersPerCube = users.getUsers();
    })

    myApp.factory('users', function($http) {
       return {
         getUsers: function() {
           var deferred = $q.defer();
           var url = "http://localhost/api/api/index.php/analytics/UsersPerCube?callback=JSON_CALLBACK";
         $http.get(url).success(function (data, status, headers, config) {
                console.log(data);
                deferred.resolve(data);
            }).error(function (data, status, headers, config) {
                //this always gets called
                console.log(status);
                deferred.reject(status);
            });
            return deferred.promise;

     }
   }

请注意,我已经编辑了我的服务器端代码,现在收到

"angular.callbacks._1( {"cube":"1","points":"160"},{"cube":"2","points":"690"},{"cube":"3","points":"331"})"

更新 以上内容有效,现在正在执行成功方法。我只需要弄清楚如何解析对象。一旦我弄清楚答案,我会再次发布。

4

2 回答 2

29

我决定详细描述如何执行jsonp请求,这样其他人就不会遇到和我一样的麻烦。

myApp.factory('users', function($http) {
       return {
         getUsers: function() {
           var deferred = $q.defer();
           var url = "http://localhost/api/api/index.php/analytics/UsersPerCube?callback=JSON_CALLBACK";
         $http.get(url).success(function (data, status, headers, config) {
                console.log(data);
                deferred.resolve(data);
            }).error(function (data, status, headers, config) {
                //this always gets called
                console.log(status);
                deferred.reject(status);
            });
            return deferred.promise;

     }  

请注意,该 url 包含?callback=JSON_CALLBACK. 这是一个很好的stackoverflow。 收到响应后,您将收到如下所示的 json。

"angular.callbacks._1( {"cube":"1","points":"160"},{"cube":"2","points":"690"},{"cube":"3","points":"331"})"

这是关于该主题的一个很好的stackoverflow

现在让我感到惊讶的是服务器必须返回GET参数,callback. 这是一个很好的教程。 http://niryariv.wordpress.com/2009/05/05/jsonp-quickly/所以json看起来像上面的那个。

好吧,我希望这对将来的某人有所帮助。

于 2013-11-11T23:37:50.063 回答
1

如果你想通过 $http 服务发出多个 JSONP 请求,你应该使用一点技巧。定期将 JSON_CALLBACK 更改为内部值,以及使用下一个解决方案的最佳方法:将此 js 代码放入返回的 js 文件中:

var callbackId = '_' + (angular.callbacks.counter - 1).toString(36);
angular.callbacks[callbackId](/* YOUR JSON */);

为确保此代码适用于您,请检查角度来源中的createHttpBackend方法。

于 2016-03-14T12:23:51.547 回答