Fajną techniką, którą zacząłem stosować z niektórymi moimi aplikacjami w express, jest stworzenie obiektu, który łączy zapytanie, parametry i pola treści obiektu żądania express.
//./express-data.js
const _ = require("lodash");
class ExpressData {
/*
* @param {Object} req - express request object
*/
constructor (req) {
//Merge all data passed by the client in the request
this.props = _.merge(req.body, req.params, req.query);
}
}
module.exports = ExpressData;
Następnie w ciele kontrolera lub w dowolnym innym miejscu w łańcuchu wyraźnych żądań możesz użyć czegoś takiego jak poniżej:
//./some-controller.js
const ExpressData = require("./express-data.js");
const router = require("express").Router();
router.get("/:some_id", (req, res) => {
let props = new ExpressData(req).props;
//Given the request "/592363122?foo=bar&hello=world"
//the below would log out
// {
// some_id: 592363122,
// foo: 'bar',
// hello: 'world'
// }
console.log(props);
return res.json(props);
});
To sprawia, że miło i wygodnie jest po prostu „zagłębić się” we wszystkie „niestandardowe dane”, które użytkownik mógł wysłać z prośbą.
Uwaga
Dlaczego pole „rekwizyty”? Ponieważ był to fragment kodu, używam tej techniki w wielu moich interfejsach API, przechowuję również dane uwierzytelniające / autoryzacyjne w tym obiekcie, przykład poniżej.
/*
* @param {Object} req - Request response object
*/
class ExpressData {
/*
* @param {Object} req - express request object
*/
constructor (req) {
//Merge all data passed by the client in the request
this.props = _.merge(req.body, req.params, req.query);
//Store reference to the user
this.user = req.user || null;
//API connected devices (Mobile app..) will send x-client header with requests, web context is implied.
//This is used to determine how the user is connecting to the API
this.client = (req.headers) ? (req.headers["x-client"] || (req.client || "web")) : "web";
}
}