How to Get the Transfer History of an NFT
This tutorial uses the alchemy_getAssetTransfers endpoint.
If you’re building a marketplace like OpenSea, an NFT price estimator, or an analytics platform like Nansen, chances are you will want to trace the ownership history of an NFT and display this information to your customers.

An example of BAYC #5672’s transfer history
There are a couple of ways to trace the ownership history of an NFT. One way is to parse all transactions of the blockchain since the genesis block, filter for transactions associated with the NFT, then display that information in a human-readable format. Typically, this method involves a massive amount of engineering resources and time.
A more straightforward way is to use Alchemy’s Transfers API and bypass the effort required to ingest and analyze an entire blockchain. This article details how to use the Alchemy Transfer API to get the ownership and transfer history of an NFT.
Creating the NFT Transfer History Script
In this tutorial, we will write a script in Node that retrieves the transfer history of an NFT in the Bored Ape Yacht Club collection. We will achieve this by using Alchemy and the Transfers API.

Prerequisites
Before you begin the steps in this tutorial, ensure you complete the following steps:
- Install both Node.js (> 14) and npm on your local machine.
- If you do not have node or npm installed, you can find instructions to install them How to Set Up Core Web3 Developer Tools. To check your Node version, run the following command in your terminal:
 
Step 1: Create an Alchemy app
To create an Alchemy app, sign up for a free account and:
- 
From Alchemy’s dashboard, hover over the Apps drop-down menu and choose Create App. 
- 
Fill out the fields in the Create App form: - Provide a Name and Description for your app.
- For Chain, select Ethereum.
- For Network select Mainnet.
 
- 
Click the Create App button. 

Creating an app on the Alchemy Dashboard
Once you have created your app, click on your app’s View Key button in the dashboard and save the API KEY. We will use this later.
Step 2: Create a Node project
Let’s create an empty repository. We can use the built-in fetch API (Node.js 18+) to make requests to the Transfers API, or install axios as an alternative. Run the following commands in your terminal:
This creates a repository named nft-transfers with all the files and dependencies we need. Open this repo in your preferred code editor (e.g., VS Code). We will write the remainder of our code in the main.js file.
Step 3: Get the transfer history of a particular NFT
To get the transfer history of a particular NFT, we will use the getAssetTransfers function. This function accepts several required and optional arguments. In our example, we will use the following arguments:
- fromBlock: The block to start tracing transfer history from. We will set this to the genesis block or- 0x0.
- contractAddresses: A list of contract addresses we want to trace transfer history for. In our case, this will be just the main BAYC contract.
- category: A list of categories of transactions we want to track. In our case, we only want to track- erc721and- tokentransactions.
- excludeZeroValue: A Boolean flag to exclude transfers with zero value. We will set this to- falsesince we are interested in all transfers.
The function also takes in other arguments that allow us to filter transactions by origin wallet address, destination wallet address, etc. For the list of parameters, check out the Transfers API
By default, Alchemy returns only the first 1000 transactions recorded for that particular smart contract. If you want to get subsequent transactions, you need to set the pageKey argument.
Since the BAYC contract has hundreds of thousands of transactions, we will focus on only the first 1000 for the sake of simplicity.
Add the following code to the main.js file, being sure to use your Alchemy API key:
Check out the code comments for more information about what the function achieves.
Run this script by typing the following command in your terminal:
If successful, you should see output that looks something like this:
You can see that the BAYC #3 was minted to address 0xab..03 and then transferred from 0xab..03 to 0x03..68.
Conclusion
Congratulations! You just used the Alchemy Transfer’s API to retrieve the transfer history for BAYC #3! You can adapt this script to retrieve the history for other NFTs in a collection or even for collections on other blockchain networks (e.g., Polygon).
If you enjoyed this tutorial about how to trace the transfer history of NFTs, tweet us at @Alchemy and give us a shoutout!
Don’t forget to join our Discord server to meet other blockchain devs, builders, and entrepreneurs!
Ready to start using the Alchemy NFT API? Create a free Alchemy account and do share your project with us!