HTTPError.net

The fastest way to diagnose, understand, and fix any HTTP status code

429 Too Many Requests

Fault: Client
TL;DR

Rate limit exceeded.

The user has sent too many requests in a given amount of time.

What This Error Means

The user has sent too many requests in a given amount of time.

Rate limit exceeded.

Common Causes

How to Fix It (For Visitors)

How to Fix It (For Developers/Admins)

Code Examples

Here's how to return a 429 status code in various programming languages:

Python (Flask)

from flask import Flask, jsonify

app = Flask(__name__)

@app.route('/endpoint')
def endpoint():
    return jsonify({"message": "Too Many Requests"}), 429

Node.js (Express)

const express = require('express');
const app = express();

app.get('/endpoint', (req, res) => {
    res.status(429).json({ message: 'Too Many Requests' });
});

PHP

<?php
http_response_code(429);
header('Content-Type: application/json');
echo json_encode(['message' => 'Too Many Requests']);
?>

Go

package main

import (
    "encoding/json"
    "net/http"
)

func handler(w http.ResponseWriter, r *http.Request) {
    w.Header().Set("Content-Type", "application/json")
    w.WriteHeader(429)
    json.NewEncoder(w).Encode(map[string]string{
        "message": "Too Many Requests",
    })
}

Java (Spring Boot)

@GetMapping("/endpoint")
public ResponseEntity<Map<String, String>> endpoint() {
    Map<String, String> response = new HashMap<>();
    response.put("message", "Too Many Requests");
    return ResponseEntity.status(429).body(response);
}

Ruby (Sinatra)

get '/endpoint' do
    status 429
    json message: 'Too Many Requests'
end

Browser Compatibility

Browser Support Notes
Chrome✓ Full SupportAll versions
Firefox✓ Full SupportAll versions
Safari✓ Full SupportAll versions
Edge✓ Full SupportAll versions

Official Specification

This status code is defined in RFC 6585.

View on IANA HTTP Status Code Registry →