Do you want to add some cool Spotify features to your website, such as displaying your current playing song, creating a custom music player, or showing off your playlists? If so, you will need to use the Spotify Web API, which lets you access and manipulate Spotify data. However, the Spotify Web API requires authentication and authorization from both you and your users, which means you will need to get an access token and a refresh token for each user. This can be tricky and risky if you don’t do it right. In this blog post, I will show you how you can generate refresh tokens for the Spotify Web API using only your browser and a few lines of code. All you need is:
- A registered application on the Spotify Developer Dashboard
- A web browser with developer tools enabled
- Node.js
Ready? Let’s get started!
Prepare your Spotify application
Assuming you already have a registered application on the Spotify Developer Dashboard, you will need to save the Client ID and Client Secret from the Overview page somewhere safe for the next step.
They will look like this:
You will also need to change the Redirect URIs in the application settings to http://localhost:3000/callback
.
Know the appropriate scopes
The scopes you need depend on the API you want to use. Each API has a specific scope that grants access to it. You can find a list of scopes and their corresponding APIs at their official documentation.
Create a local server to get the generated refresh token
- Save the code snippet below as get-token.js
- Go to the directory where you saved your get-token.js. Run the following command:
- Run the local server:
- Open your browser and enter this address
http://localhost:3000/login
. You will get your tokens as an array result from two API calls: the first one is to get an access token and refresh token, and the second one is to grant the refresh token.
There you go. You finally have your refresh token for your website. You can continue to implement Spotify on your website now, which I also have an example of in using Spotify API with Vite and Cloudflare Workers. Feel free to check it out.