Restricting API calls to my own Next.js project to prevent spam

Hey everyone,

I have a Next.js project hosted on Vercel, and I’m running into a big issue: people are scraping my API endpoints and spamming them, causing huge Function Duration usage. As a result, I’m facing a massive bill due to traffic from non-legitimate users.

I’d like to set things up so that these endpoints can only be called from my own website/project and not be publicly accessible to anyone. Is there a recommended way—either via Next.js configuration or Vercel settings—to ensure only my site can call these APIs?

I’d really appreciate any guidance or best practices. This month, my bill skyrocketed to $1000, whereas I usually pay around $40. If someone from the Vercel team can also jump in to help, that would be amazing. I can’t afford these unexpected charges caused by spam traffic.

Thanks in advance for your help!

Hi, @littatech!

@earlrobb shared this very helpful post recently, he created rules that target these URLs specifically.

I’ll also share some other potentially helpful content related to the Firewall:

Let us know how you have any other specific questions!

Thank you for your reply!
I’ll read everything :muscle:

I quickly tried to enable vercel WAF, but having this “We’re verifying your browser” everytime someone visit my website is not possible.
Do you know if it’s possible to only enable it for the API? (so it’s hidden and users don’t even know there is a verification?

Hello,

You can configure custom rules in your Vercel Firewall to enable Challenge for specific request path: WAF Custom Rules

So should I add a rule like that?

I don’t get everything on WAF Custom rules

This topic was automatically closed 30 days after the last reply. New replies are no longer allowed.