我正在尝试从 Premier League Fantasy Football 网站提取一些数据,但未能达到第 22 条军规的要求。
我的 AJAX JSONP 脚本如下所示:
function getPlayer(playerNumber) {
$.ajax({
url: 'http://fantasy.premierleague.com/web/api/elements/' + playerNumber + '/',
dataType: 'jsonp',
success : function(responseText) {
alert(responseText);
},
error : function(XMLHttpRequest, textStatus, errorThrown) {
if (XMLHttpRequest.status != 200)
alert('getPlayer failed!');
},
complete : function(jqXHR) {
alert('complete');
}
});
}
这会生成错误SyntaxError:缺失;之前的声明
我相信是因为此页面上已接受的答案: AJAX call and clean JSON but Syntax Error: missing ; before statement
将 dataType 更改为 json 意味着我违反了此处所述的同源策略。
令我烦恼的是,当我使用 JSONP 版本时,我得到状态 200,并且可以在 Firefox 调试器中看到完整的“对象”结构。
那么 Firefox 正在做什么来获取我没有获取的数据?
最佳答案
好吧,看来我从错误的 Angular 来看待这个问题。显然 Firefox 没有使用 JS 来获取数据,所以最终我也没有使用 JS 来获取数据。
PHP cURL 成功了:
$curlSession = curl_init();
curl_setopt($curlSession, CURLOPT_URL, 'http://fantasy.premierleague.com/web/api/elements/' . $playerId);
curl_setopt($curlSession, CURLOPT_BINARYTRANSFER, true);
curl_setopt($curlSession, CURLOPT_RETURNTRANSFER, true);
$result = curl_exec($curlSession);
$player = json_decode($result, true);
curl_close($curlSession);
关于javascript - 通过跨站点 AJAX 解释 JSONP,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35114975/