【问题标题】:How to request jsonp without 'callback' in the URL如何在 URL 中请求没有“回调”的 jsonp
【发布时间】:2017-09-28 10:39:45
【问题描述】:

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

但是我注意到如果 url 包含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 中访问它?

【问题讨论】:

  • 并非所有 api 都可以通过 ajax 访问。在您的服务器或第三方服务上使用代理

标签: javascript jquery json xml xslt


【解决方案1】:

您不能将& 添加为查询参数初始化程序,而必须使用?

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

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

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

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");
  })
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.0/jquery.min.js"></script>

【讨论】:

    猜你喜欢
    • 2013-12-07
    • 2017-12-30
    • 2015-01-31
    • 1970-01-01
    • 2016-11-14
    • 2015-06-22
    • 1970-01-01
    • 2019-09-11
    • 2017-11-19
    相关资源
    最近更新 更多