Bird
Raised Fist0
Expressframework~5 mins

Rate limiting with express-rate-limit

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Introduction

Rate limiting helps protect your web app from too many requests at once. It stops overload and keeps your app running smoothly.

To stop users from sending too many requests and slowing down your server.
To protect login pages from repeated password guessing.
To limit API usage for free users in a service.
To prevent spam or abuse on forms or endpoints.
To keep your server stable during traffic spikes.
Syntax
Express
import rateLimit from 'express-rate-limit';

const limiter = rateLimit({
  windowMs: 15 * 60 * 1000, // time frame in milliseconds
  max: 100, // max requests per windowMs
  message: 'Too many requests, please try again later.',
});

app.use(limiter);

windowMs sets the time window for counting requests.

max is the max number of requests allowed in that window.

Examples
Limits to 10 requests per minute.
Express
const limiter = rateLimit({ windowMs: 60000, max: 10 });
Limits to 50 requests every 5 minutes with a custom message.
Express
const limiter = rateLimit({ windowMs: 5 * 60 * 1000, max: 50, message: 'Slow down!' });
Applies rate limiting only to routes starting with /api/.
Express
app.use('/api/', rateLimit({ windowMs: 10 * 60 * 1000, max: 100 }));
Sample Program

This Express app limits each IP to 5 requests every 15 minutes. If exceeded, it sends a friendly error message.

Express
import express from 'express';
import rateLimit from 'express-rate-limit';

const app = express();

const limiter = rateLimit({
  windowMs: 15 * 60 * 1000, // 15 minutes
  max: 5, // limit each IP to 5 requests per windowMs
  message: 'Too many requests, please try again later.',
});

app.use(limiter);

app.get('/', (req, res) => {
  res.send('Hello, world!');
});

app.listen(3000, () => {
  console.log('Server running on http://localhost:3000');
});
OutputSuccess
Important Notes

Rate limiting works by tracking requests per IP address.

You can customize the error message to be user-friendly.

Use rate limiting especially on login and API routes to improve security.

Summary

Rate limiting protects your app from too many requests at once.

Use express-rate-limit to easily add limits in Express.

Set windowMs and max to control request limits.

Practice

(1/5)
1. What is the main purpose of using express-rate-limit in an Express app?
easy
A. To handle database connections efficiently
B. To speed up the server response time
C. To automatically restart the server on code changes
D. To limit the number of requests a user can make in a time window

Solution

  1. Step 1: Understand the purpose of rate limiting

    Rate limiting is used to protect the server by restricting how many requests a user can send in a short time.
  2. Step 2: Identify what express-rate-limit does

    This package helps set these limits easily in Express apps.
  3. Final Answer:

    To limit the number of requests a user can make in a time window -> Option D
  4. Quick Check:

    Rate limiting = limit requests [OK]
Hint: Rate limiting controls request count per time window [OK]
Common Mistakes:
  • Thinking it speeds up server responses
  • Confusing it with server restart tools
  • Assuming it manages database connections
2. Which of the following is the correct way to import and use express-rate-limit in an Express app?
easy
A. const rateLimit = require('express-rate-limit'); app.use(rateLimit({ windowMs: 60000, max: 5 }));
B. const rateLimit = require('express-rate-limit'); app.use(rateLimit());
C. import rateLimit from 'express-rate-limit'; app.use(rateLimit());
D. import rateLimit from 'express-rate-limit'; app.use(rateLimit);

Solution

  1. Step 1: Check import style for CommonJS

    Using require is correct for many Express apps.
  2. Step 2: Verify usage of rateLimit function with options

    We must call rateLimit with an options object like { windowMs: 60000, max: 5 } to set limits.
  3. Final Answer:

    const rateLimit = require('express-rate-limit'); app.use(rateLimit({ windowMs: 60000, max: 5 })); -> Option A
  4. Quick Check:

    Import + call with options = B [OK]
Hint: Call rateLimit with options object, not empty or missing [OK]
Common Mistakes:
  • Forgetting to call rateLimit as a function
  • Using import without proper setup
  • Passing rateLimit directly without options
3. Given this code snippet, what will happen if a user sends 7 requests within 1 minute?
const rateLimit = require('express-rate-limit');
const limiter = rateLimit({ windowMs: 60000, max: 5 });
app.use(limiter);
medium
A. All 7 requests will be accepted without any limit
B. Only the first 2 requests will be accepted; the rest will be blocked
C. Only the first 5 requests will be accepted; the next 2 will be blocked
D. The server will crash after 5 requests

Solution

  1. Step 1: Understand the max and windowMs settings

    The limit is 5 requests per 60000 milliseconds (1 minute).
  2. Step 2: Analyze the request count

    The first 5 requests are allowed; requests 6 and 7 exceed the limit and get blocked.
  3. Final Answer:

    Only the first 5 requests will be accepted; the next 2 will be blocked -> Option C
  4. Quick Check:

    max 5 requests = C [OK]
Hint: Requests over max in windowMs get blocked [OK]
Common Mistakes:
  • Assuming all requests pass without limit
  • Thinking limit resets before 1 minute
  • Believing server crashes on limit
4. Identify the error in this code snippet for rate limiting:
const rateLimit = require('express-rate-limit');
const limiter = rateLimit({ max: 10 });
app.use(limiter);
medium
A. Incorrect import statement for express-rate-limit
B. Missing windowMs option to define the time window
C. Using max instead of limit option
D. Calling app.use before defining limiter

Solution

  1. Step 1: Check required options for rateLimit

    The windowMs option is needed to specify the time frame for the limit.
  2. Step 2: Identify missing option

    The code only sets max but does not set windowMs, so the time window is undefined.
  3. Final Answer:

    Missing windowMs option to define the time window -> Option B
  4. Quick Check:

    windowMs missing = A [OK]
Hint: Always set windowMs with max for rateLimit [OK]
Common Mistakes:
  • Forgetting windowMs causes no time limit
  • Confusing max with limit option
  • Wrong import syntax
5. You want to apply rate limiting only to the login route to prevent brute force attacks. Which code snippet correctly applies express-rate-limit only to /login?
hard
A. app.use('/login', rateLimit({ windowMs: 60000, max: 5 }));
B. app.use(rateLimit({ windowMs: 60000, max: 5 })); app.use('/login');
C. app.get('/login', rateLimit({ windowMs: 60000, max: 5 }));
D. app.post(rateLimit({ windowMs: 60000, max: 5 }), '/login');

Solution

  1. Step 1: Understand how to apply middleware to specific routes

    Using app.use('/login', middleware) applies the middleware only to the /login path.
  2. Step 2: Check the correct syntax for rateLimit middleware

    Calling rateLimit with options returns middleware to pass to app.use.
  3. Final Answer:

    app.use('/login', rateLimit({ windowMs: 60000, max: 5 })); -> Option A
  4. Quick Check:

    Middleware on route = A [OK]
Hint: Use app.use with path and rateLimit middleware [OK]
Common Mistakes:
  • Calling app.use without path for specific routes
  • Using app.get or app.post incorrectly with middleware
  • Passing middleware after route string