Weiterleitung (Routing)
Der Begriff Weiterleitung (Routing) bezieht sich auf die Definition von Anwendungsendpunkten (URIs) und deren Antworten auf Clientanforderungen. Eine Einführung in dieses Routing siehe Basisrouting.
You define routing using methods of the Express app
object that correspond to HTTP methods;
for example, app.get()
to handle GET requests and app.post
to handle POST requests. For a full list,
see app.METHOD. You can also use app.all() to handle all HTTP methods and app.use() to
specify middleware as the callback function (See Using middleware for details).
These routing methods specify a callback function (sometimes called “handler functions”) called when the application receives a request to the specified route (endpoint) and HTTP method. In other words, the application “listens” for requests that match the specified route(s) and method(s), and when it detects a match, it calls the specified callback function.
In fact, the routing methods can have more than one callback function as arguments.
With multiple callback functions, it is important to provide next
as an argument to the callback function and then call next()
within the body of the function to hand off control
to the next callback.
Der folgende Code ist ein Beispiel für ein sehr einfaches Basisrouting.
const express = require('express')
const app = express()
// respond with "hello world" when a GET request is made to the homepage
app.get('/', (req, res) => {
res.send('hello world')
})
Weiterleitungsmethoden
Eine Weiterleitungsmethode wird von einer HTTP-Methode abgeleitet und an eine Instanz der Klasse express
angehängt.
Der folgende Code ist ein Beispiel für Weiterleitungen, die für die Methoden GET und POST zum Stamm (Root) der Anwendung definiert werden.
// GET method route
app.get('/', (req, res) => {
res.send('GET request to the homepage')
})
// POST method route
app.post('/', (req, res) => {
res.send('POST request to the homepage')
})
Express supports methods that correspond to all HTTP request methods: get
, post
, and so on.
For a full list, see app.METHOD.
Es gibt eine spezielle Weiterleitungsmethode, app.all()
, die nicht von einer HTTP-Methode abgeleitet wird. Diese Methode wird zum Laden von Middlewarefunktionen bei einem Pfad für alle Anforderungsmethoden verwendet. Im folgenden Beispiel wird der Handler für Anforderungen zur Weiterleitung “/secret” ausgeführt, um herauszufinden, ob Sie GET-, POST-, PUT-, DELETE- oder andere HTTP-Anforderungsmethoden verwenden, die im HTTP-Modul unterstützt werden.
app.all('/secret', (req, res, next) => {
console.log('Accessing the secret section ...')
next() // pass control to the next handler
})
Weiterleitungspfade
Über Weiterleitungspfade werden in Kombination mit einer Anforderungsmethode die Endpunkte definiert, bei denen Anforderungen erfolgen können. Weiterleitungspfade können Zeichenfolgen, Zeichenfolgemuster oder reguläre Ausdrücke sein.
Caution
In express 5, the characters ?
, +
, *
, []
, and ()
are handled differently than in version 4, please review the migration guide for more information.
Caution
In express 4, regular expression characters such as $
need to be escaped with a \
.
Note
Express uses path-to-regexp for matching the route paths; see the path-to-regexp documentation for all the possibilities in defining route paths. Express Route Tester ist ein handliches Tool zum Testen von Express-Basisweiterleitungen, auch wenn dieses Tool keine Musterabgleiche unterstützt.
Warning
Query strings are not part of the route path.
Route paths based on strings
Dieser Weiterleitungspfad gleicht Weiterleitungsanforderungen zum Stammverzeichnis (/
) ab.
app.get('/', (req, res) => {
res.send('root')
})
Dieser Weiterleitungspfad gleicht Anforderungen mit /about
ab.
app.get('/about', (req, res) => {
res.send('about')
})
Dieser Weiterleitungspfad gleicht Anforderungen mit /random.text
ab.
app.get('/random.text', (req, res) => {
res.send('random.text')
})
Route paths based on string patterns
Caution
The string patterns in Express 5 no longer work. Please refer to the migration guide for more information.
Dieser Weiterleitungspfad gleicht acd
und abcd
ab.
app.get('/ab?cd', (req, res) => {
res.send('ab?cd')
})
Dies sind einige Beispiele für Weiterleitungspfade auf Basis von Zeichenfolgemustern.
app.get('/ab+cd', (req, res) => {
res.send('ab+cd')
})
Dies sind einige Beispiele für Weiterleitungspfade auf Basis von Zeichenfolgen.
app.get('/ab*cd', (req, res) => {
res.send('ab*cd')
})
Dieser Weiterleitungspfad gleicht /abe
und /abcde
ab.
app.get('/ab(cd)?e', (req, res) => {
res.send('ab(cd)?e')
})
Route paths based on regular expressions
Dieser Weiterleitungspfad gleicht alle Weiterleitungsnamen ab, die den Buchstaben “a” enthalten.
app.get(/a/, (req, res) => {
res.send('/a/')
})
Dieser Weiterleitungspfad gleicht butterfly
und dragonfly
, jedoch nicht butterflyman
, dragonfly man
usw.
app.get(/.*fly$/, (req, res) => {
res.send('/.*fly$/')
})
Route parameters
Route parameters are named URL segments that are used to capture the values specified at their position in the URL. The captured values are populated in the req.params
object, with the name of the route parameter specified in the path as their respective keys.
Route path: /users/:userId/books/:bookId
Request URL: http://localhost:3000/users/34/books/8989
req.params: { "userId": "34", "bookId": "8989" }
To define routes with route parameters, simply specify the route parameters in the path of the route as shown below.
app.get('/users/:userId/books/:bookId', (req, res) => {
res.send(req.params)
})
The name of route parameters must be made up of “word characters” ([A-Za-z0-9_]).
Since the hyphen (-
) and the dot (.
) are interpreted literally, they can be used along with route parameters for useful purposes.
Route path: /flights/:from-:to
Request URL: http://localhost:3000/flights/LAX-SFO
req.params: { "from": "LAX", "to": "SFO" }
Route path: /plantae/:genus.:species
Request URL: http://localhost:3000/plantae/Prunus.persica
req.params: { "genus": "Prunus", "species": "persica" }
Caution
In express 5, Regexp characters are not supported in route paths, for more information please refer to the migration guide.
To have more control over the exact string that can be matched by a route parameter, you can append a regular expression in parentheses (()
):
Route path: /user/:userId(\d+)
Request URL: http://localhost:3000/user/42
req.params: {"userId": "42"}
Warning
Because the regular expression is usually part of a literal string, be sure to escape any \
characters with an additional backslash, for example \\d+
.
Warning
In Express 4.x, the *
character in regular expressions is not interpreted in the usual way. As a workaround, use {0,}
instead of *
. This will likely be fixed in Express 5.
Routenhandler (Weiterleitungsroutinen)
Sie können mehrere Callback-Funktionen angeben, die sich wie Middleware verhalten, um eine Anforderung zu verarbeiten. Die einzige Ausnahme hierbei ist, dass diese Callbacks möglicherweise next('route')
aufrufen, um die verbleibenden Weiterleitungs-Callbacks zu umgehen. Mit diesem Verfahren können Sie Vorabbedingungen für eine Weiterleitung festlegen und dann die Steuerung an nachfolgende Weiterleitungen übergeben, wenn kein Grund vorliegt, mit der aktuellen Weiterleitung fortzufahren.
Routenhandler können eine Funktion und/oder ein Funktionsarray sein, wie in den folgenden Beispielen zu sehen ist.
Eine einzelne Callback-Funktion kann eine Weiterleitung verarbeiten. Beispiel:
app.get('/example/a', (req, res) => {
res.send('Hello from A!')
})
Mehrere Callback-Funktionen können eine Weiterleitung verarbeiten (achten Sie darauf, dass Sie das Objekt next
angeben). Beispiel:
app.get('/example/b', (req, res, next) => {
console.log('the response will be sent by the next function ...')
next()
}, (req, res) => {
res.send('Hello from B!')
})
Ein Array von Callback-Funktionen kann eine Weiterleitung verarbeiten. Beispiel:
const cb0 = function (req, res, next) {
console.log('CB0')
next()
}
const cb1 = function (req, res, next) {
console.log('CB1')
next()
}
const cb2 = function (req, res) {
res.send('Hello from C!')
}
app.get('/example/c', [cb0, cb1, cb2])
Eine Kombination aus unabhängigen Funktionen und Funktionsarrays kann eine Weiterleitung verarbeiten. Beispiel:
const cb0 = function (req, res, next) {
console.log('CB0')
next()
}
const cb1 = function (req, res, next) {
console.log('CB1')
next()
}
app.get('/example/d', [cb0, cb1], (req, res, next) => {
console.log('the response will be sent by the next function ...')
next()
}, (req, res) => {
res.send('Hello from D!')
})
Antwortmethoden
Über die Methoden für das Antwortobjekt (res
) in der folgenden Tabelle kann eine Antwort an den Client gesendet und der Anforderung/Antwort-Zyklus beendet werden. Wenn keine dieser Methoden über einen Routenhandler aufgerufen wird, bleibt die Clientanforderung im Status “blockiert”.
Methode | Beschreibung |
---|---|
res.download() | Gibt eine Eingabeaufforderung zum Herunterladen einer Datei aus. |
res.end() | End the response process. |
res.json() | Sendet eine JSON-Antwort. |
res.jsonp() | Sendet eine JSON-Antwort mit JSONP-Unterstützung. |
res.redirect() | Leitet eine Anforderung um. |
res.render() | Render a view template. |
res.send() | Sendet eine Antwort mit unterschiedlichen Typen. |
res.sendFile | Sendet eine Datei als Oktett-Stream. |
res.sendStatus() | Legt den Antwortstatuscode fest und sendet dessen Zeichenfolgedarstellung als Antworthauptteil. |
app.route()
Sie können mithilfe von app.route()
verkettbare Routenhandler für einen Weiterleitungspfad erstellen.
Da der Pfad an einer einzelnen Position angegeben wird, ist das Erstellen modularer Weiterleitungen hilfreich, da Redundanzen und Schreibfehler reduziert werden. Weitere Informationen zu Weiterleitungen finden Sie in der Dokumentation zu Router().
Dies ist ein Beispiel für verkettete Routenhandler, die mit der Funktion app.route()
definiert werden.
app.route('/book')
.get((req, res) => {
res.send('Get a random book')
})
.post((req, res) => {
res.send('Add a book')
})
.put((req, res) => {
res.send('Update the book')
})
express.Router
Mit der Klasse express.Router
lassen sich modular einbindbare Routenhandler erstellen. Eine Router
-Instanz ist ein vollständiges Middleware- und Routingsystem. Aus diesem Grund wird diese Instanz oft auch als “Mini-App” bezeichnet.
Im folgenden Beispiel wird ein Router als Modul erstellt, eine Middlewarefunktion in das Modul geladen, es werden Weiterleitungen definiert und das Modul letztendlich in einen Pfad in der Hauptanwendung eingebunden.
Erstellen Sie eine Routerdatei namens birds.js
mit dem folgenden Inhalt im Anwendungsverzeichnis:
const express = require('express')
const router = express.Router()
// middleware that is specific to this router
const timeLog = (req, res, next) => {
console.log('Time: ', Date.now())
next()
}
router.use(timeLog)
// define the home page route
router.get('/', (req, res) => {
res.send('Birds home page')
})
// define the about route
router.get('/about', (req, res) => {
res.send('About birds')
})
module.exports = router
Laden Sie dann das Routermodul in die Anwendung:
const birds = require('./birds')
// ...
app.use('/birds', birds)
Die Anwendung kann nun Anforderungen an die Pfade /birds
und /birds/about
bearbeiten und ruft die Middlewarefunktion timeLog
auf, die speziell für diese Weiterleitung bestimmt ist.
But if the parent route /birds
has path parameters, it will not be accessible by default from the sub-routes. To make it accessible, you will need to pass the mergeParams
option to the Router constructor reference.
const router = express.Router({ mergeParams: true })