成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

五種高級 NodeJS 技術

開發 前端
作為開發人員,我們都致力于打造高效、健壯且易于理解、修改和擴展的代碼庫。 通過采用最佳實踐和探索先進技術,我們可以釋放 NodeJS 的真正潛力并顯著提高應用程序的質量。

作為開發人員,我們都致力于打造高效、健壯且易于理解、修改和擴展的代碼庫。 通過采用最佳實踐和探索先進技術,我們可以釋放 NodeJS 的真正潛力并顯著提高應用程序的質量。 在這篇文章中,我們將重點介紹 NodeJS 的五種高級技術。 所以,系好安全帶,我們要開車了,準備好探索它們吧。

1.添加中間件

不要將中間件添加到每個路由,而是使用 use 方法將其添加到路由列表的頂部。 這樣,中間件下面定義的任何路由都會在到達各自的路由處理程序之前自動通過中間件。

const route = express.Router();
const {login} = require("../controllers/auth");


route.get('/login', login)


// isAuthenticated is middleware that checks whether 
// you are authenticated or not
// // ? Avoid this: middleware on each route
route.get('/products', isAuthenticated, fetchAllProducts);
route.get('/product/:id', isAuthenticated, getProductById)
// ? Instead, do this
// Route without middleware
route.get('/login', login)


// Middleware function: isAuthenticated
// This will be applied to all routes defined after this point
route.use(isAuthenticated);


// Routes that will automatically check the middleware
route.get('/products', fetchAllProducts);
route.get('/product/:id', getProductById);

這種方法有助于保持代碼的組織性,并避免為每個路由單獨重復中間件。

2.使用全局錯誤處理

我們可以使用 NodeJS 全局錯誤處理功能,而不是在每個控制器上構建錯誤響應。 首先,創建一個派生自內置 Error 類的自定義 AppError 類。 此自定義類允許您使用 statusCode 和 status 等附加屬性來自定義錯誤對象。

// Custom Error class
module.exports = class AppError extends Error {
  constructor(message, statusCode) {
    super(message);
    this.statusCode = statusCode;
    this.status = statusCode < 500 ? "error" : "fail";


    Error.captureStackTrace(this, this.constructor);
  }
};

創建自定義錯誤類后,請在根路由器文件中添加全局錯誤處理程序中間件。 該中間件函數采用四個參數(err、req、res、next)并處理整個應用程序中的錯誤。 

在全局錯誤處理程序中,您可以根據錯誤對象的 statusCode、status 和 message 屬性來格式化錯誤響應。 

您可以自定義此響應格式以滿足您的需求。 此外,還包括用于開發環境的堆棧屬性。

// Express setup
const express = require('express');


const app = express();


app.use('/', (req, res) => {
  res.status(200).json({ message: "it works" });
});


app.use('*', (req, res) => {
    res.status(404).json({
        message: `Can't find ${req.originalUrl} this route`,
    });
});


// ?? add a global error handler after all the routes.
app.use((err, req, res, next) => {
  err.status = err.status || "fail";
  err.statusCode = err.statusCode || 500;


  res.status(err.statusCode).json({
    status: err.status,
    message: transformMessage(err.message),
    stack: process.env.NODE_ENV === "development" ? err.stack : undefined,
  });
});

添加后,您可以使用 next(new AppError(message, statusCode)) 拋出錯誤。 下一個函數會自動將錯誤傳遞給全局錯誤處理程序中間件。

// inside controllers


// route.get('/login', login);


exports.login = async (req, res, next) => {
  try {
    const { email, password } = req.body;


    const user = await User.findOne({ email }).select("+password +lastLoginAt");


    if (!user || !(await user.correctPassword(password, user.password))) {
      // ?? like this
      return next(new AppError("Invalid Email / Password / Method", 404));
    }


     // Custom logic for generating a token
    const token = 'generated_token';


    res.status(200).json({ token });
  } catch(error) {
      next(error
  }
});

總體而言,這種方法通過將錯誤處理集中在一個位置來簡化錯誤處理,從而更輕松地在應用程序中維護和自定義錯誤響應。

3.使用自定義Try-Catch函數

我們可以使用實現相同目的的自定義函數,而不是使用 try-catch 塊手動包裝每個控制器函數。

// ? Avoid this
// Using try-catch block each controllers
exports.login = async (req, res, next) => {
  try {
    // logic here
  } catch(error) {
      res.status(400).json({ message: 'You error message'}
  }
});

tryCatchFn 函數接受函數 (fn) 作為輸入,并返回一個用 try-catch 塊包裝原始函數的新函數。 

如果在包裝函數內發生錯誤,則使用 catch 方法捕獲錯誤,并將錯誤傳遞到下一個函數以由全局錯誤處理程序處理。

// ? Instead, do this
const tryCatchFn = (fn) => {
  return (req, res, next) => {
    fn(req, res, next).catch(next);
  };
}


// To use this custom function, you can wrap your controller 
// functions with tryCatchFn:
exports.login = tryCatchFn(async (req, res, next) => {
  // logic here
});

通過使用 tryCatchFn 包裝控制器函數,您可以確保自動捕獲這些函數中引發的任何錯誤并將其傳遞給全局錯誤處理程序,從而無需單獨添加 try-catch 塊。

這種方法有助于以更清晰、更簡潔的方式集中錯誤處理,使代碼更易于維護并減少重復的錯誤處理代碼。

4. 將主文件分成兩部分。

使用 Express 開發 NodeJS 應用程序時,通常有一個包含所有業務邏輯、路由定義和服務器設置的主文件。 

然而,隨著應用程序的增長,管理和維護處理所有事情的單個文件可能會變得困難。

解決此問題并保持代碼庫更干凈、更有條理的一種推薦技術是將主文件分為兩部分:一個用于路由,另一個用于服務器設置或配置。 

這是一個例子:

// app.js
const express = require('express');
const app = express();


/* Middlewares */


app.get('/', (req, res) => {
  res.status(200).json({ message: "it works" });
})


app.use(/* Global Error Handler */);
module.exports = app;


// server.js
const app = require('./app');
const port = process.env.PORT || 5001;


app.listen(port, () => console.log('Server running at', port));

5. 將路由與控制器分開

為了實現更有組織性和模塊化的代碼庫,我建議將路由與控制器分開。 這種做法有助于保持清晰的關注點分離,并提高代碼的可讀性和可維護性。 

這是一個演示路由和控制器分離的示例。

// ? Avoid this
const route = express.Router();


route.get('/login', tryCatchFn(req, res, next) => {
  // logic here
}))


// ? Do this
const route = express.Router();
const {login} = require("../controllers/auth");


route.get('/login', login);

結論

在本文中,我們討論了編寫干凈且易于維護的 NodeJS 代碼的不同高級技術。 有許多最佳實踐可以顯著提高應用程序代碼的質量。 

責任編輯:華軒 來源: web前端開發
相關推薦

2013-11-06 09:27:11

2024-09-03 13:59:37

2011-09-22 13:47:35

云計算數據管理PaaS

2009-10-27 10:14:02

無線接入技術

2022-08-22 08:40:42

API網關開發

2023-04-14 15:07:05

架構開發自動化工具

2013-07-02 17:48:51

Android數據存儲Android

2023-05-09 15:01:43

JavaScript編程語言異常處理

2024-09-30 13:15:57

2014-04-22 09:34:12

大數據

2021-07-07 10:59:48

python代碼編程語言

2024-07-26 00:19:55

2023-04-28 15:22:53

2020-03-23 13:16:05

前端跨平臺開發

2013-05-03 09:42:10

2019-08-01 11:27:46

數據復制數據源中間層

2022-10-12 00:13:20

數據分析人工智能數據可視化

2021-09-13 09:43:50

存儲技術存儲軟件定義存儲

2023-03-01 13:55:11

智能建筑能源浪費

2022-02-18 00:05:07

編程語言Java技術
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一区二区三区小视频 | 日韩亚洲欧美综合 | 国产精品久久久久久网站 | 一区2区| 成人免费在线播放视频 | chinese中国真实乱对白 | 中文精品一区二区 | 午夜99| 日本黄色的视频 | 91精品国产综合久久久久久漫画 | 亚洲视频在线播放 | 国产成人综合一区二区三区 | 伊人精品| www.99热这里只有精品 | 天天躁日日躁狠狠的躁天龙影院 | 亚洲高清视频一区二区 | 国产日韩欧美一区二区 | 国产高清在线精品 | 亚洲人成人网 | 日韩有码一区 | 玖玖国产 | 最新伦理片 | 中文字幕一级毛片 | 国产精品国产自产拍高清 | 国产一区二区黑人欧美xxxx | 久久精品网 | 国产高清免费视频 | 国产精品日韩欧美一区二区三区 | 欧美成人精品激情在线观看 | 欧美日韩综合 | 美日韩一区二区 | 欧美性区 | 偷拍自拍网站 | 亚洲精品一区二区三区在线观看 | 国产毛片久久久久久久久春天 | 日韩精品视频在线 | 黄色网页在线观看 | 中文字幕亚洲欧美 | 欧美视频二区 | 久久国产精品无码网站 | 国产精品美女久久久免费 |