我对javascript和网络编程非常陌生,我需要一些帮助。我有一个HTTP请求,我需要通过javascript发送,并需要将输出存储在一个变量中。我尝试只使用调用url:
https://api.fantasydata.net/nfl/v2/JSON/PlayerSeasonStats/2015
但是它返回了一个身份验证错误,因为我没有发送我的API密钥,它也没有告诉我如何在URL中执行此操作。 API密钥被列为标题而不是参数,我不知道如何处理它。我尝试使用XMLHttpRequest()类,但我不太确定我到底知道它做了什么,也不能让它工作。
实际的HTTP请求
GET https://api.fantasydata.net/nfl/v2/JSON/PlayerSeasonStats/2015 HTTP/1.1
Host: api.fantasydata.net
Ocp-Apim-Subscription-Key: ••••••••••••••••••••••••••••••••
我只需要弄清楚如何将该请求与密钥一起发送,以及如何将它返回的JSON doc存储为javascript中的变量。
编辑:这是我到目前为止所做的:
function testingAPI(){
var key = "8a1c6a354c884c658ff29a8636fd7c18";
httpGet("https://api.fantasydata.net/nfl/v2/JSON/PlayerSeasonStats/2015",key );
alert(xmlHttp.responseText);
var x = 0;
}
function httpGet(theUrl,key)
{
var xmlHttp = new XMLHttpRequest();
xmlHttp.open( "GET", theUrl, false ); // false for synchronous request
xmlHttp.setRequestHeader("Ocp-Apim-Subscription-Key",key);
xmlHttp.send( null );
return xmlHttp.responseText;
}
谢谢!
答案 0 :(得分:8)
如果它说API密钥被列为标题,则很可能需要在http请求的headers
选项中进行设置。通常是这样的:
headers: {'Authorization': '[your API key]'}
以下是另一个Question
的示例$http({method: 'GET', url: '[the-target-url]', headers: {
'Authorization': '[your-api-key]'}
});
编辑:刚看到您想将响应存储在变量中。在这种情况下,我可能只是使用AJAX。像这样:
$.ajax({
type : "GET",
url : "[the-target-url]",
beforeSend: function(xhr){xhr.setRequestHeader('Authorization', '[your-api-key]');},
success : function(result) {
//set your variable to the result
},
error : function(result) {
//handle the error
}
});
我从this question得到了这个,我正在工作,所以我现在无法测试它,但看起来很稳固
编辑2:非常确定您应该可以使用此行:
headers: {'Authorization': '[your API key]'},
而不是第一次修改中的beforeSend
行。这对你来说可能更简单
答案 1 :(得分:0)
使用您自己的代码和轻微更改 withjQuery,
function testingAPI(){
var key = "8a1c6a354c884c658ff29a8636fd7c18";
var url = "https://api.fantasydata.net/nfl/v2/JSON/PlayerSeasonStats/2015";
console.log(httpGet(url,key));
}
function httpGet(url,key){
var xmlHttp = new XMLHttpRequest();
xmlHttp.open( "GET", url, false );
xmlHttp.setRequestHeader("Ocp-Apim-Subscription-Key",key);
xmlHttp.send(null);
return xmlHttp.responseText;
}
谢谢