cari

Rumah  >  Soal Jawab  >  teks badan

Terokai fungsi fungsi "seterusnya" dalam perisian tengah Express dan peranannya dalam mengubah hala ke fungsi lain.

Saya baru menggunakan Nodejs dan mengusahakan Express js dan kini saya sedang mengusahakan "fungsi perisian tengah" untuk laluan tertentu dan saya ingin tahu "untuk apa yang akan digunakan seterusnya", bermakna selepas mengesahkan perkara yang boleh dilakukan oleh fungsi "seterusnya"? Jika kita ingin mengalihkan/mengalih ke fungsi lain maka bagaimana kita melakukannya? Apakah itu "checkAuthentication"? Ini kod semasa saya

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

// Custom middleware function
const authMiddleware = (req, res, next) => {
  // Check if user is authenticated
  const isAuthenticated = checkAuthentication(req);
  
  if (isAuthenticated) {
    next();
  } else {
    // User is not authenticated, send an unauthorized response
    res.status(401).send('Unauthorized');
  }
};

// Middleware function is applied to specific routes
app.get('/protected', authMiddleware, (req, res) => {
  res.send('Protected Route');
});

// Route handler
app.get('/', (req, res) => {
  res.send('Home Page');
});

// Start the server
app.listen(3000, () => {
  console.log('Server is listening on port 3000');
});

P粉195402292P粉195402292277 hari yang lalu501

membalas semua(1)saya akan balas

  • P粉738676186

    P粉7386761862024-04-03 16:05:48

    Seterusnya ialah fungsi panggil balik yang dihantar ke fungsi middleware. Anda boleh menemuinya di bawah nama yang berbeza dalam rangka kerja yang berbeza tetapi konsepnya tetap sama.

    Saya akan cuba menerangkan middleware melalui kod anda sendiri.

    const express = require('express');
    const app = express();
    
    function checkAuthentication(req) {
      /*
      I am considering this as my authentication function. 
      When the user logged in, server has sent him a token, which now will act as a validator. 
      */
    
      if (req.headers.token) {
        const user = someFunctionToFetchUser(req.header.token)
        return user
      } else {
        return false
      }
    }
    
    /*
    Now I want a function to be there on each protected api routes
    to make user if user has a valid token then only allow them to interact with the data base otherwise throw an error 
    */
    
    
    const authMiddleware = (req, res, next) => {
      // Check if user is authenticated
      const isAuthenticated = checkAuthentication(req);
    
      if (isAuthenticated) {
        // Now you have verified the has valid a token. So allow user 
        // to reach to the controller or any other middleware, if any.
        next();
      } else {
        // User is not authenticated, send an unauthorized response
        res.status(401).send('Unauthorized');
      }
    };
    
    // Middleware function is applied to specific routes
    app.get('/protected', authMiddleware, (req, res) => {
      res.send('Protected Route');
    });
    
    // You can have any number of middlewares
    app.get('/protected', authMiddleware, someOtherMiddleware, (req, res) => {
      res.send('Protected Route');
    });
    
    // And also you can pass data from middleware to next middleware/controller also by attahching it with request
    
    function newMiddleware(req, res, next) {
      req.foo = "bar" //Now you can access this foo variable in next function.
    }

    balas
    0
  • Batalbalas