我正在做一个超级杀手项目,它使用Spotify Web Api。我正在使用Spotify Api包装器库(https://github.com/thelinmichael/spotify-web-api-java)。我正在使用授权代码流(https://developer.spotify.com/documentation/general/guides/authorization-guide/#authorization-code-flow)。这意味着当用户授予访问权限时,Spotify将我重定向到带有访问令牌的本地主机。长话短说,我能够用ServerSocket创建一个本地主机服务器,我可以让用户授予或拒绝对Spotify的访问,并且它完美地在localhost链接中生成访问令牌。我的问题是无法从回调链接(https://example.com/callback?code=NApCCg..BkWtQ&state=profile%2Factivity)获得这个访问令牌/代码。我知道我必须遵循重定向,而且我的猜测是Spotify进行的重定向超过1次,因为我的代码输出如下:
URL url = new URL("https://accounts.spotify.com/authorize?client_id=123EXAMPLECODE&redirect_uri=http://localhost:8080&response_type=code");
HttpURLConnection ucon = (HttpURLConnection) url.openConnection();
ucon.setInstanceFollowRedirects(false);
URL secondURL = new URL(ucon.getHeaderField("Location"));
URLConnection conn = secondURL.openConnection();
System.out.println(secondURL);您可以看到,它将我从“授权”重定向到“登录”,然后返回到本地主机,我能够跟踪重定向到登录。我怎样才能跟随它到本地主机呢?或者有任何方法从回调中获取此代码吗?
我很感谢你的帮助!
发布于 2020-04-15 12:00:45
我设法用getQuery()方法从HttpExchange的回调链接中获得令牌。请认为这个问题已经解决了。
https://stackoverflow.com/questions/61214372
复制相似问题