400 vs 404: Bad Request vs Not Found

400 and 404 can look similar in logs, but they tell clients, crawlers, and API consumers different things.

Aspect400404
MeaningBad Request describes how the server processed the request and what the client should do next.Not Found describes how the server processed the request and what the client should do next.
Typical use caseHTTP 400 Bad Request indicates a client errors response outcome.HTTP 404 Not Found indicates a client errors response outcome.
Caching/client behaviorCheck cache headers and downstream behavior for 400.Check cache headers and downstream behavior for 404.
SEO implicationsSearch crawlers interpret 400 according to client-errors semantics.Search crawlers interpret 404 according to client-errors semantics.
API/backend impactAPI clients may branch logic specifically on 400.API clients may branch logic specifically on 404.

When to use one vs the other

Use 400 when the response should communicate bad request behavior; use 404 when not found is the accurate protocol signal.

A frequent mistake is swapping 400 and 404 for convenience; that causes client retry bugs, incorrect cache signals, and misleading monitoring data.

Decision summary: if user agents should receive the Bad Request signal, return 400; if they should receive Not Found, return 404.

FAQ

What is the biggest difference between 400 and 404?

400 communicates Bad Request, while 404 communicates Not Found. Choosing the right one keeps clients and intermediaries predictable.

Do 400 and 404 have SEO or caching impact?

Yes. Search engines and caches interpret status classes differently. Use each code according to its semantics to avoid accidental indexing, stale responses, or crawl inefficiency.

Can APIs safely return 400 instead of 404?

Only when it matches contract semantics. API clients often branch logic by exact code, so swapping them can break retries, auth handling, or user-facing errors.

Related guides: 400 Bad Request ยท 404 Not Found

Related comparisons