Middleware functions are functions that take 3 arguments for example(function(req, res, next) { console.log(“I’m a middleware…”); next(); }
the request object, the response object, and the next function in the application’s request-response cycle.hese functions execute some code that can have side effects on the app, and usually add informations to the request or response objects.They can also end the cycle sending the response, when some condition is met. If they don’t send the response, when they are done they start the execution of the next function in the stack. This is triggered calling the 3rd argument next(). More information in the express documentation. In this exercise we are going to build a root-level middleware. As we have seen in challenge 4, to mount a middleware function at root level we can use the method app.use(
Build a simple logger. For every request, it should log in the console a string taking the following format: method path - ip. An example would look like: GET /json - ::ffff:127.0.0.1. Note that there is a space between method and path and that the dash separating path and ip is surrounded by a space on either side. You can get the request method (http verb), the relative route path, and the caller’s ip from the request object, using req.method, req.path and req.ip. Remember to call next() when you are done, or your server will be stuck forever. Be sure to have the ‘Logs’ opened, and see what happens when some request arrives…
app.use(function middleware(req, res, next) { // Do something var string = req.method + ‘ ‘ + req.path + ‘ - ‘ + req.ip; console.log(string); // Call the next function in line: next(); });
Middleware can be mounted at a specific route using app.METHOD(path, middlewareFunction). Middleware can also be chained inside route definition. This approach is useful to split the server operations into smaller units. That leads to a better app structure, and the possibility to reuse code in different places. This approach can also be used to perform some validation on the data. At each point of the middleware stack you can block the execution of the current chain and pass control to functions specifically designed to handle errors. Or you can pass control to the next matching route, to handle special cases. We will see how in the advanced Express section.In the route app.get(‘/now’, …) chain a middleware function and the final handler. In the middleware function you should add the current time to the request object in the req.time key. You can use new Date().toString(). In the handler, respond with a JSON object, taking the structure {time: req.time}.
app.get(‘/now’, function(req, res, next) { req.time= new Date().toString() // Hypothetical synchronous operation next(); }, function(req, res) { res.send( {time: req.time}); })
When building an API, we have to allow users to comunicate us what they want to get from our service. For example, if the client is requesting information about a user stored in the database, they need a way to let us know which user they’re interested in. One possible way to achieve this result is using route parameters. Route parameters are named segments of the URL, delimited by slashes (/). Each segment captures the value of the part of the URL which matches its position. The captured values can be found in the req.params object.
route_path: ‘/user/:userId/book/:bookId’ actual_request_URL: ‘/user/546/book/6754’ req.params: {userId: ‘546’, bookId: ‘6754’} Build an echo server, mounted at the route GET /:word/echo. Respond with a JSON object, taking the structure {echo: word}. You can find the word to be repeated at req.params.word. You can test your route from your browser’s address bar, visiting some matching routes, e.g. your-app-rootpath/freecodecamp/echo code app.get(“/:word/echo”, function(req, res) { //word = req.params.word; let word=req.params.word // respond with the json object res.json({echo: word}) });
Another common way to get input from the client is by encoding the data after the route path, using a query string. The query string is delimited by a question mark (?), and includes field=value couples. Each couple is separated by an ampersand (&). Express can parse the data from the query string, and populate the object req.query. Some characters cannot be in URLs, they have to be encoded in a different format before you can send them. If you use the API from JavaScript, you can use specific methods to encode/decode these characters.
route_path: ‘/library’ actual_request_URL: ‘/library?userId=546&bookId=6754’ req.query: {userId: ‘546’, bookId: ‘6754’} Build an API endpoint, mounted at GET /name. Respond with a JSON document, taking the structure { name: ‘firstname lastname’}. The first and last name parameters should be encoded in a query string e.g. ?first=firstname&last=lastname.
app.get(“/name”, function(req, res) {
var firstName= req.query.first;
var lastName = req.query.last;
let jsonObj = { name:${firstName} ${lastName}
};
console.log(jsonObj);
res.send(jsonObj);
});