Was ist Express-Middleware? Wie verwende ich es in Node? Der folgende Artikel führt Sie in die einfache Verwendung der Express-Middleware ein. Ich hoffe, er wird Ihnen hilfreich sein!
Middleware bezieht sich speziell auf die Zwischenverarbeitungsverbindung von Geschäftsprozessen.
Wenn eine Anfrage den Express-Server erreicht, können mehrere Middlewares kontinuierlich aufgerufen werden, um die Anfrage vorzuverarbeiten.
ist im Wesentlichen eine Funktionsverarbeitungsfunktion
Hinweis: Die formale Parameterliste der Middleware-Funktion muss den nächsten Parameter enthalten. Die Routing-Verarbeitungsfunktion enthält nur req und res,
// next参数必须在最后一个传入 const mw = (req, res, next) => { ... // next()必须在最后调用 next() }
next-Funktion ist der Schlüssel zum kontinuierlichen Aufruf mehrerer Middlewares. Dies bedeutet, dass die Zirkulationsbeziehung auf die nächste Middleware übertragen wird oder Routing.
Jede vom Client initiierte Anfrage löst die Middleware aus, nachdem sie den Server erreicht hat. Dies wird als global wirksame Middleware bezeichnet. Durch den Aufruf von server.use (Middleware-Funktion) können Sie eine global wirksame Middleware definieren. Der Beispielcode lautet wie folgt:
const mw = (req, res, next) => { next() } const mw1 = (req, res, next) => { next() } // 全局生效的中间件,中间件调用顺序以传入顺序为准 server.use(mw,mw1)
Lokale Middleware funktioniert nur auf einem angegebenen Routing-Pfad. Effektiv
const mw = (req, res, next) => { next() } const mw1 = (req, res, next) => { next() } // 局部生效的中间件 server.get('/',mw,(req,res)=>{ res.send('路径:/') }) // 定义多个局部生效的中间件 // 1、直接逗号分隔 server.get('/',mw,mw1,(req,res)=>{ res.send('路径:/') }) // 2、或者使用数组包含 server.get('/',[mw,mw1],(req,res)=>{ res.send('路径:/') })
Mehrere Middlewares teilen sich die gleichen Anforderungen und Auflösungen. Basierend auf dieser Funktion können wir einheitlich benutzerdefinierte Attribute oder Methoden zu den req- oder res-Objekten in der Upstream-Middleware hinzufügen, um sie von Downstream-Middleware oder Routing zu verwenden.
const mw = (req, res, next) => { // 添加属性 req.startTime=new Date() next() }
Stellen Sie sicher, dass Sie die Middleware vor dem Routing registrieren
Vom Kunden gesendete Anforderungen können kontinuierlich mehrere Middleware zur Verarbeitung aufrufen
Nach der Geschäftsausführung Code der Middleware, vergessen Sie nicht, die Funktion next() aufzurufen. Teilen Sie Anforderungs- und Res-Objekte zwischen mehreren Middlewares.
// 全局生效的中间件(应用级别的中间件) server.use(mw,mw1) // 局部生效的中间件(应用级别的中间件) server.get('/',mw,mw1,(req,res)=>{ res.send(`请求进入服务器的时间:${req.startTime}`) })
const router = require('./router/router') // 路由级别的中间件 router.use((req,res,next)=>{ next() })
Hinweis: Nach allen Routen muss die Fehlerebenen-Middleware registriert werden!
// 人为制造错误 server.get('/err', (req, res) => { throw new Error('人为抛出错误!!!') res.send('err Page') }) // 定义错误级别的中间件 server.use((err, req, res, next) => { console.log('发生了错误:' + err.message); res.send('Error:'+err.message) next() })
// 配置解析application/json格式数据的内置中间件 server.use(express.json()) // 配置解析application/x-www-form-urlencoded格式数据的内置中间件 server.use(express.urlencoded({ extended: false })) // 测试解析json的内置中间件 server.post('/user',(req,res)=>{ // 在服务器,可以使用req.body这个属性来接受客户端发送过来的请求数据 // 默认情况下,如果不配置解析表单数据的中间件,则req.body默认等于undefined console.log(req.body); res.send('ok') }) // 测试解析urlencoded的内置中间件 server.post('/book',(req,res)=>{ console.log(req.body) res.send('book ok') })
express@4.16.0
wurde häufig die Drittanbieter-Middleware body-parser
zum Parsen der Anforderungstextdaten verwendet. Die Verwendungsschritte sind wie folgt:
Führen Sie npm install body-parser
aus, um die Middleware zu installieren. server.use( )
Registrieren und Middleware nutzen Hinweis: Die in Express integrierte express.urlencoded-Middleware ist basierend auf dem Middleware-Body-Parser eines Drittanbieters weiter gekapselt.
Weitere Informationen zu Knoten finden Sie unter: nodejs-Tutorial!
Das obige ist der detaillierte Inhalt vonWas ist Express-Middleware? Wie verwende ich es in Node?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!