我已经看了几天Spotify api和示例源代码,我仍然无法弄清楚如何获取访问令牌来访问用户的播放列表数据。我已经达到了拉起登录窗口,用户登录,然后我收到授权码的程度。此时,我尝试过这样的事情:
window.open("https://accounts.spotify.com/api/token?
grant_type=authorization_code&code="+code+"&redirect_uri=myurl&client_id=3137b15
2f1424defa2c6020ae5c6d444&client_secret=mysecret");
和
$.ajax(
{
url: "https://accounts.spotify.com/api/token?grant_type=authorization_code&code="+code+"&redirect_uri=myurl&client_secret=mysecret&client_id=myid",
success: function(result){
alert("foo");
}
}
);
但不管怎样,我得到的结果如下:
{"error":"server_error","error_description":"Unexpected status: 405"}
而不是令牌。我确信这很简单但我在JS很糟糕。请帮忙!谢谢!
(编辑)我忘了提及:
链接到api身份验证指南:https://developer.spotify.com/web-api/authorization-guide/
我坚持第4步。我发现有一种替代方法可以发送"标头参数"或cURL请求可能有效。但是,由于我不知道如何做这些事情,我一直坚持发送client_id和client_secret作为身体请求参数,就像我之前为用户登录/代码所做的那样。
PS:我只使用这个应用程序我自己写作。有没有办法在不经过这个过程的情况下对令牌进行硬编码?
答案 0 :(得分:5)
收到授权代码后,您需要通过向Spotify帐户服务发出POST请求来与访问令牌进行交换,这次是将其与/ api / token端点交换:< / p>
因此,您需要使用请求正文中的参数向Spotify API发出POST请求:
$.ajax(
{
method: "POST",
url: "https://accounts.spotify.com/api/token",
data: {
"grant_type": "authorization_code",
"code": code,
"redirect_uri": myurl,
"client_secret": mysecret,
"client_id": myid,
},
success: function(result) {
// handle result...
},
}
);
(作为旁注,&#34;意外状态:405&#34; 是指HTTP状态代码 405 Method Not Allowed ,表示请求方法你试过 - 在这个URL上不允许GET请求。)