This time we’re going bigger than ever. Fabric, Power BI, SQL, AI and more. We're covering it all. You won't want to miss it.
Learn moreLevel up your Power BI skills this month - build one visual each week and tell better stories with data! Get started
Hello. I am trying to figure out how to stream/download the exported PDF file from a Power BI API Export call. I'm using a NodeJS backend with a React frontend. Here's what I'm trying to do in the backend:
const queryResults = await fetch(`https://api.powerbi.com/v1.0/myorg/groups/${workspaceId}/reports/${reportId}/exports/${exportId}/file`, {
method: 'GET',
headers: {
'content-type': 'application/pdf',
authorization: `Bearer ${(await getAccessToken()).accessToken}`
}
});
return queryResults;
Solved! Go to Solution.
Hi @trpeel ,
It sounds like you are trying to download a PDF file that has been exported from a Power BI report using the Power BI API. However, it return size 0. The possible reason is the API call is not correctly authenticated. Please update the code as below and check if it can return the expected result...
const fetch = require('node-fetch');
const workspaceId = '<your workspace ID>';
const reportId = '<your report ID>';
const exportId = '<your export ID>';
const accessToken = '<your access token>';
const url = `https://api.powerbi.com/v1.0/myorg/groups/${workspaceId}/reports/${reportId}/exports/${exportId}/file`;
const options = {
method: 'GET',
headers: {
'Content-Type': 'application/pdf',
'Authorization': `Bearer ${accessToken}`
}
};
fetch(url, options)
.then(response => {
if (!response.ok) {
throw new Error(`HTTP error ${response.status}`);
}
return response.buffer();
})
.then(buffer => {
// Do something with the PDF buffer, such as write it to a file or send it to the client
})
.catch(error => {
console.error(error);
});
Best Regards
Thank you very much. The response.buffer was the part I was missing. I appreciate the help.
Hi @trpeel ,
It sounds like you are trying to download a PDF file that has been exported from a Power BI report using the Power BI API. However, it return size 0. The possible reason is the API call is not correctly authenticated. Please update the code as below and check if it can return the expected result...
const fetch = require('node-fetch');
const workspaceId = '<your workspace ID>';
const reportId = '<your report ID>';
const exportId = '<your export ID>';
const accessToken = '<your access token>';
const url = `https://api.powerbi.com/v1.0/myorg/groups/${workspaceId}/reports/${reportId}/exports/${exportId}/file`;
const options = {
method: 'GET',
headers: {
'Content-Type': 'application/pdf',
'Authorization': `Bearer ${accessToken}`
}
};
fetch(url, options)
.then(response => {
if (!response.ok) {
throw new Error(`HTTP error ${response.status}`);
}
return response.buffer();
})
.then(buffer => {
// Do something with the PDF buffer, such as write it to a file or send it to the client
})
.catch(error => {
console.error(error);
});
Best Regards
Check out the April 2026 Power BI update to learn about new features.
Sign up to receive a private message when registration opens and key events begin.
If you have recently started exploring Fabric, we'd love to hear how it's going. Your feedback can help with product improvements.
| User | Count |
|---|---|
| 4 | |
| 2 | |
| 1 | |
| 1 | |
| 1 |