如何在URL中请求没有'回调'的jsonp

时间:2017-04-30 22:17:24

标签: javascript jquery json xml xslt

我正在尝试从Icecast广播电台检索信息。 API提供了status-json.xsl来获取这些数据。虽然格式为xsl,但我相信它会返回一个JSON文件。

但是我注意到,如果网址包含status-json.xsl&callback=1,服务器不会返回数据...所以我正在寻找另一种获取数据的方法,而不会导致跨域错误..

这是我的代码:

var dataURL = "http://relay-chi.gameowls.com:8000/status-json.xsl" + "&callback=?";
$.getJSON(dataURL, function(data) {
  console.log(data);
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

上面的代码给出了错误:GET http://relay-chi.gameowls.com:8000/status-json.xsl&callback=jQuery2140976016339879229_1493590443216?_=1493590443217

因此http://relay-chi.gameowls.com:8000/status-json.xsl提供了正确的数据,我如何在jQuery中访问它?

1 个答案:

答案 0 :(得分:1)

您无法将&添加为查询参数初始值设定项,而必须使用?

所以网址看起来像http://relay-chi.gameowls.com:8000/status-json.xsl?callback=test&...

但是,我可以看到API不接受回调。

相反,使用以下代码可以获取数据,但主机.gameowls.com不接受跨源请求! (打开浏览器控制台获取更多信息)

&#13;
&#13;
var dataURL = "http://relay-chi.gameowls.com:8000/status-json.xsl";

$.ajax( dataURL )
  .done(function(data) {
    console.log('data =>', data );
  })
  .fail(function() {
    console.log( "error");
  })
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.0/jquery.min.js"></script>
&#13;
&#13;
&#13;