What if one small missing check lets strangers see your private data?
Why Protecting routes with auth middleware in Express? - Purpose & Use Cases
Start learning this pattern below
Jump into concepts and practice - no test required
Imagine you have a website where some pages should only be seen by logged-in users. You try to check if someone is logged in on every page manually by writing the same code again and again inside each route.
Doing this manually means repeating code everywhere, which is tiring and easy to forget. If you miss one place, unauthorized users might see private info. It also makes your code messy and hard to fix later.
Auth middleware lets you write the login check once and then apply it to any route you want to protect. This keeps your code clean, safe, and easy to manage.
app.get('/dashboard', (req, res) => { if (!req.user) { return res.redirect('/login'); } res.send('Welcome to your dashboard'); });
function authMiddleware(req, res, next) {
if (!req.user) return res.redirect('/login');
next();
}
app.get('/dashboard', authMiddleware, (req, res) => {
res.send('Welcome to your dashboard');
});This lets you easily protect many routes with one simple function, making your app safer and your code cleaner.
Think of a gym where only members can enter certain rooms. Instead of checking membership at every door separately, a guard (middleware) checks once and lets members pass smoothly.
Manual checks cause repeated code and risk mistakes.
Auth middleware centralizes login checks for safety and clarity.
Protecting routes becomes simple and reliable.
Practice
Solution
Step 1: Understand middleware role
Middleware runs before route handlers to process requests.Step 2: Identify auth middleware function
Auth middleware specifically checks user permissions to allow or deny access.Final Answer:
To check if a user is allowed to access a route -> Option AQuick Check:
Auth middleware = Access control [OK]
- Confusing auth middleware with logging middleware
- Thinking middleware serves static files
- Assuming middleware formats response data
Solution
Step 1: Recall Express route syntax
Middleware functions come before the final route handler in the argument list.Step 2: Check each option's order
Only app.get('/profile', authMiddleware, (req, res) => { res.send('Profile'); }); places authMiddleware correctly before the handler function.Final Answer:
app.get('/profile', authMiddleware, (req, res) => { res.send('Profile'); }); -> Option AQuick Check:
Middleware before handler = app.get('/profile', authMiddleware, (req, res) => { res.send('Profile'); }); [OK]
- Placing middleware after the handler
- Passing middleware as the first argument instead of path
- Calling middleware inside the handler instead of passing it
function authMiddleware(req, res, next) {
if (req.headers.authorization === 'valid-token') {
next();
} else {
res.status(401).send('Unauthorized');
}
}
app.get('/dashboard', authMiddleware, (req, res) => {
res.send('Welcome to dashboard');
});Solution
Step 1: Analyze authMiddleware logic
If the authorization header equals 'valid-token', next() is called to continue.Step 2: Check behavior when token is missing or invalid
Else block sends 401 Unauthorized response and does not call next(), blocking access.Final Answer:
The user gets a 401 Unauthorized response if token is missing or invalid -> Option CQuick Check:
Invalid token = 401 Unauthorized [OK]
- Assuming next() is always called
- Thinking user always sees dashboard
- Confusing 401 with 404 errors
function authMiddleware(req, res, next) {
if (!req.user) {
res.status(403).send('Forbidden');
}
next();
}Solution
Step 1: Understand middleware flow
If !req.user is true, response is sent with status 403.Step 2: Check what happens after sending response
next() is called unconditionally after the if block, so it runs even after response sent, causing errors.Final Answer:
next() is called even after sending a response, causing an error -> Option BQuick Check:
Call next() only if no response sent [OK]
- Calling next() after res.send()
- Not stopping middleware after response
- Using wrong status codes for auth errors
function authMiddleware(req, res, next) {
if (!req.headers.authorization) {
return res.status(401).send('Unauthorized');
}
req.userId = req.headers.authorization;
next();
}
// How to apply this middleware and log userId for routes '/profile' and '/settings'?Solution
Step 1: Understand middleware application
app.use(authMiddleware) applies middleware to all routes defined after it, protecting multiple routes easily.Step 2: Logging userId in route handlers
Since authMiddleware sets req.userId, route handlers can access and log it safely after middleware runs.Final Answer:
Use app.use(authMiddleware) before defining both routes, then log req.userId inside each route handler -> Option DQuick Check:
Use app.use for shared middleware [OK]
- Applying middleware only to some routes inconsistently
- Calling middleware inside handlers manually
- Applying middleware after route handlers
