Node.js express middleware for capturing HTTP requests and responses
npm install @clearonline/express-request-capturevar requestCapture = require ('@clearonline/express-request-capture')When using this module with express or connect, simply app.use the module.
Request information url, request, response, status, latency, and clientIp, is printed/stored to the specified channel!
var requestCapture = require ('express-request-capture'),
    express = require ('express')
var app = express()
var printAdapter = { channel: 'console|http|mongo|mysql', url: 'required if channel is either http or database' };
app.use(requestCapture(printAdapter))// sample response
{
    url: "https://alert.clearonline.org/api/v1/subscribe",
    method: "POST",
    status: 200,
    latency: 100,
    request: {
        headers: {
            "Content-Type": "application/json"
        },
        body: {
            email: "[email protected]",
            trigger: "solar energy"
        },
        host: "localhost:3000",
        clientIp: "192.111.1.1"
    },
    response: {
        header: {
            "Date": "2017-06-02T22:29:44.315Z"
        },
        body: {
            message: "Thank you for subscribing, i will send you notes every monday!"
        }
    }
}Monitoring your web app is one the many ways to prevent hackers from breaking your app. In this tutorial, we do this by creating an expressjs middleware that logs all information related to the received request and return response.
Capture all requests (request and response) that my express application handles.
- initialize npm package
 
mkdir express-request-capture && cd express-request-capture
npm init -y- create 
index.jsfile 
# this will be the entry/main file of our middleware
touch index.js- add content to 
index.jsfile 
module.exports = require('./src/capture.js')- create the 
srcfolder 
mkdir src- 
create a
capture.jsfile insidesrc - 
put logic inside the
capture.jsfile - 
publish to npm
 
npm login
npm publish- 
- use the middleware