1

我正在使用本教程: http ://rabidgadfly.com/2013/02/angular-and-xml-no-problem/

为了启动 XML 的应用程序,当我设置外部 xml(Feedburner)时告诉我我无权访问,有人知道它可能是什么吗?

HTML:

<section ng-controller="AppController" class="container-podcastapp">
         <ul>
            <li ng-repeat="guitar in dataSet">
               <div class="resultwrapper">
                   <h2>{{item.title}}</h2>
                </div>
            </li>   
          </ul>
    </section>

javascript:

angular.module('myApp.service',[]).
    factory('DataSource', ['$http',function($http){
       return {
           get: function(file,callback,transform){
                $http.get(
                    file,
                    {transformResponse:transform}
                ).
                success(function(data, status) {
                    console.log("Request succeeded");
                    callback(data);
                }).
                error(function(data, status) {
                    console.log("Request failed " + status);
                });
           }
       };
    }]);

angular.module('myApp',['myApp.service']);

var AppController = function($scope,DataSource) {

    var SOURCE_FILE = "http://rss.cnn.com/services/podcasting/ac360/rss.xml";

    xmlTransform = function(data) {
        console.log("transform data");
        var x2js = new X2JS();
        var json = x2js.xml_str2json( data );
        return json.item;
    };

    setData = function(data) {
        $scope.dataSet = data;
    };

    DataSource.get(SOURCE_FILE,setData,xmlTransform);

};
4

1 回答 1

0

“方法不允许”通常意味着您发送请求的服务被配置为禁止某种请求类型(POST, GET, OPTIONS)。

由于您正在尝试(据我所知)使用该GET方法,因此我建议您尝试使用POST.

另一方面,在某些情况下,服务器会一起禁止跨域 ajax 请求 - 您查询的这个 URL 很可能不是服务器上的真正静态文件,而是某种服务,在这种情况下,必须对其进行配置允许来自不同域的 Ajax 请求。

如果您可以发布您获得的整个错误/响应(使用 Fiddler 或其他),那将很有帮助,以防使用POST无法完成工作。

编辑:

尝试对您的服务进行以下更改:

angular.module('myApp.service',[]).
factory('DataSource', ['$http',function($http){
   return {
       get: function(file,callback,transform){
            $http.post(file, {}, {transformResponse:transform}). // this is the change
            success(function(data, status) {
                console.log("Request succeeded");
                callback(data);
            }).
            error(function(data, status) {
                console.log("Request failed " + status);
            });
       }
   };
}]);
于 2013-08-05T20:46:17.183 回答