如何获取访问令牌Spotify API?

时间:2016-10-06 04:07:13

标签: javascript html ajax xmlhttprequest spotify

我已经看了几天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:我只使用这个应用程序我自己写作。有没有办法在不经过这个过程的情况下对令牌进行硬编码?

1 个答案:

答案 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请求。)