首頁 > web前端 > js教程 > 主體

帶有中間件的 Express.js 應用程式

Susan Sarandon
發布: 2024-11-24 06:01:14
原創
934 人瀏覽過

Express.js Applications with Middleware

介紹

Express.js 中的中間件是一種強大的機制,可讓您攔截傳入請求和傳出回應。它提供了一種靈活的方法來擴展應用程式的功能,而無需修改核心路由邏輯。在這篇文章中,我們將深入研究中間件的概念,探索其各種類型,並示範如何有效地實現它。

了解中間件

中間件函數本質上是可以存取請求(req)、回應(res)和鏈中的下一個中間件(next)的函數。他們可以執行各種任務,例如:

  • 日誌記錄:記錄傳入請求和傳出回應以進行分析和偵錯。

  • 驗證:驗證使用者憑證並授權存取受保護的路由。

  • 錯誤處理:捕捉並處理應用程式中發生的錯誤。
    解析請求主體:解析傳入的請求主體(例如 JSON、表單資料)。

  • 設定回應標頭:在傳出回應中設定自訂標頭(例如 CORS 標頭)。

中介軟體類型


應用程式層級中介軟體:

  • 適用於 Express 應用程式的所有傳入請求。

  • 通常用於全域設定、日誌記錄和錯誤處理。

const express = require('express');
const app = express();

// Application-level middleware
app.use((req, res, next) => {
    console.log('Request URL:', req.url);
    next();
});
登入後複製

路由器級中間件:

  • 適用於特定路線或路線組。

  • 對於特定於路由的身份驗證、授權或資料驗證很有用。

const express = require('express');
const router = express.Router();

// Router-level middleware
router.use((req, res, next) => {
    console.log('Router-level middleware');
    next();
});

router.get('/users', (req, res) => {
    // ...
});
登入後複製

錯誤處理中介軟體:

  • 旨在處理應用程式內發生的錯誤。

  • 必須有四個參數:err、req、res 和 next。

  app.use((err, req, res, next) => {
    console.error(err.stack);
    res.status(500).send('Internal Server Error');
});
登入後複製

結論

透過有效利用中間件,您可以增強 Express.js 應用程式的安全性、效能和整體功能。了解不同類型的中間件及其適當的用例將使您能夠創建強大且可擴展的 Web 應用程式。

以上是帶有中間件的 Express.js 應用程式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:dev.to
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板