Creating Custom Middleware
In Express.js, we can create custom middleware functions using the app.use()
method. These functions take three parameters: req
(the request object), res
(the response object), and next
(a function to pass control to the next middleware in the chain). Custom middleware can be applied globally to all routes or specific routes by specifying a route path.
Creating Custom Middleware
Here's a basic example of a custom middleware function that logs the timestamp and URL of every incoming request:
app.use((req, res, next) => {
const timestamp = new Date().toISOString();
const url = req.url;
console.log(`[${timestamp}] ${url}`);
next(); // Pass control to the next middleware.
});
In this example, the custom middleware logs the timestamp and URL of each incoming request to the console. The next()
function is called to pass control to the next middleware in the pipeline.
Real-World Example: Combining Built-in and Custom Middleware
Here's a practical example where we use an Express built-in middleware to parse JSON data and then create a custom middleware to validate that data before proceeding:
const express = require('express');
const app = express();
// Use built-in middleware to parse JSON data.
app.use(express.json());
// Custom middleware to validate JSON data.
app.use((req, res, next) => {
const jsonData = req.body;
if (!jsonData || Object.keys(jsonData).length === 0) {
// If the JSON data is missing or empty, send an error response.
return res.status(400).json({ error: 'Invalid JSON data' });
}
// Data is valid; proceed to the next middleware or route.
next();
});
// Route that expects valid JSON data.
app.post('/api/data', (req, res) => {
const jsonData = req.body;
res.status(200).json({ message: 'Data received', data: jsonData });
});
app.listen(3000, () => {
console.log('Server is running on port 3000.');
});
In this example:
- We use the built-in middleware
express.json()
to parse incoming JSON data; - We create a custom middleware that checks if the parsed JSON data is missing or empty. If it is, it sends a 400 Bad Request response with an error message. If the data is valid, it calls
next()
to proceed to the route; - The
/api/data
route expects valid JSON data. If the custom middleware validates the data, the route handler receives it and sends a success response.
This example demonstrates how we can use both built-in and custom middleware to validate data before it reaches our route handlers, ensuring the data is in the expected format before processing it further.
Thanks for your feedback!
Ask AI
Ask AI
Ask anything or try one of the suggested questions to begin our chat
Can you explain how to apply middleware to specific routes only?
What are some other use cases for custom middleware in Express.js?
How does the order of middleware affect request handling in Express.js?
Awesome!
Completion rate improved to 2.56
Creating Custom Middleware
Swipe to show menu
In Express.js, we can create custom middleware functions using the app.use()
method. These functions take three parameters: req
(the request object), res
(the response object), and next
(a function to pass control to the next middleware in the chain). Custom middleware can be applied globally to all routes or specific routes by specifying a route path.
Creating Custom Middleware
Here's a basic example of a custom middleware function that logs the timestamp and URL of every incoming request:
app.use((req, res, next) => {
const timestamp = new Date().toISOString();
const url = req.url;
console.log(`[${timestamp}] ${url}`);
next(); // Pass control to the next middleware.
});
In this example, the custom middleware logs the timestamp and URL of each incoming request to the console. The next()
function is called to pass control to the next middleware in the pipeline.
Real-World Example: Combining Built-in and Custom Middleware
Here's a practical example where we use an Express built-in middleware to parse JSON data and then create a custom middleware to validate that data before proceeding:
const express = require('express');
const app = express();
// Use built-in middleware to parse JSON data.
app.use(express.json());
// Custom middleware to validate JSON data.
app.use((req, res, next) => {
const jsonData = req.body;
if (!jsonData || Object.keys(jsonData).length === 0) {
// If the JSON data is missing or empty, send an error response.
return res.status(400).json({ error: 'Invalid JSON data' });
}
// Data is valid; proceed to the next middleware or route.
next();
});
// Route that expects valid JSON data.
app.post('/api/data', (req, res) => {
const jsonData = req.body;
res.status(200).json({ message: 'Data received', data: jsonData });
});
app.listen(3000, () => {
console.log('Server is running on port 3000.');
});
In this example:
- We use the built-in middleware
express.json()
to parse incoming JSON data; - We create a custom middleware that checks if the parsed JSON data is missing or empty. If it is, it sends a 400 Bad Request response with an error message. If the data is valid, it calls
next()
to proceed to the route; - The
/api/data
route expects valid JSON data. If the custom middleware validates the data, the route handler receives it and sends a success response.
This example demonstrates how we can use both built-in and custom middleware to validate data before it reaches our route handlers, ensuring the data is in the expected format before processing it further.
Thanks for your feedback!