app.use()
est destiné à lier le middleware à votre application. Il path
s'agit d'un chemin de « montage » ou de « préfixe » et limite le middleware à ne s'appliquer qu'aux chemins demandés qui commencent par lui. Il peut même être utilisé pour intégrer une autre application:
// subapp.js
var express = require('express');
var app = modules.exports = express();
// ...
// server.js
var express = require('express');
var app = express();
app.use('/subapp', require('./subapp'));
// ...
En spécifiant /
comme chemin de « montage », app.use()
répondra à tout chemin commençant par /
, qui sont tous et indépendamment du verbe HTTP utilisé:
GET /
PUT /foo
POST /foo/bar
- etc.
app.get()
, d'autre part, fait partie du routage d'application d'Express et est destiné à faire correspondre et à gérer un itinéraire spécifique lorsque demandé avec le GET
verbe HTTP:
Et, le routage équivalent pour votre exemple app.use()
serait en fait:
app.all(/^\/.*/, function (req, res) {
res.send('Hello');
});
( Mise à jour: Tenter de mieux démontrer les différences. )
Les méthodes de routage, notamment app.get()
, sont des méthodes pratiques qui vous aident à aligner plus précisément les réponses aux demandes. Ils ajoutent également la prise en charge de fonctionnalités telles que les paramètres et next('route')
.
Dans chacun d'eux se app.get()
trouve un appel à app.use()
, donc vous pouvez certainement faire tout cela app.use()
directement. Mais cela nécessitera souvent (probablement inutilement) la réimplémentation de diverses quantités de code passe-partout.
Exemples:
Pour les itinéraires simples et statiques:
app.get('/', function (req, res) {
// ...
});
contre.
app.use('/', function (req, res, next) {
if (req.method !== 'GET' || req.url !== '/')
return next();
// ...
});
Avec plusieurs gestionnaires pour le même itinéraire:
app.get('/', authorize('ADMIN'), function (req, res) {
// ...
});
contre.
const authorizeAdmin = authorize('ADMIN');
app.use('/', function (req, res, next) {
if (req.method !== 'GET' || req.url !== '/')
return next();
authorizeAdmin(req, res, function (err) {
if (err) return next(err);
// ...
});
});
Avec paramètres:
app.get('/item/:id', function (req, res) {
let id = req.params.id;
// ...
});
contre.
const pathToRegExp = require('path-to-regexp');
function prepareParams(matches, pathKeys, previousParams) {
var params = previousParams || {};
// TODO: support repeating keys...
matches.slice(1).forEach(function (segment, index) {
let { name } = pathKeys[index];
params[name] = segment;
});
return params;
}
const itemIdKeys = [];
const itemIdPattern = pathToRegExp('/item/:id', itemIdKeys);
app.use('/', function (req, res, next) {
if (req.method !== 'GET') return next();
var urlMatch = itemIdPattern.exec(req.url);
if (!urlMatch) return next();
if (itemIdKeys && itemIdKeys.length)
req.params = prepareParams(urlMatch, itemIdKeys, req.params);
let id = req.params.id;
// ...
});
Note: La mise en œuvre d'Express de ces caractéristiques sont contenues dans son Router
, Layer
etRoute
.