关于Express中使用next()函数遇到的执行顺序问题

关于Express中使用next()函数遇到的执行顺序问题

文章目录


前言

关于next()函数是什么,我就不用多说了,下面直接看代码。

一、代码介绍

这是一个自定义解析表单数据的中间件模块

二、代码

const express = require('express')
const app = express()
const qs = require('querystring')

// 这是解析表单数据的中间件
app.use(function (req, res, next) {
    // 监听req对象的data事件,来获取客户端发到服务器的数据
    let str = '';
    // 监听data事件,拼接数据
    req.on('data', (chunk) => {
        console.log(1);  //用于测试执行顺序
        str += chunk;
    });
    // 监听end事件,数据接收完会自动触发
    req.on('end', () => {
        // 使用querystring模块解析请求体数据,专门用来处理查询字符串。
        // 通过这个模块提供的parse()函数,可以将查询字符串解析成对象的格式。
        const body = qs.parse(str);
        // 解析后将body挂载到req.body属性上
        req.body = body;
        console.log(2);  //用于测试执行顺序
        next();
    });
    // next();   ①   //用于标识(下面问题要用)
});

app.post('/save', (req, res) => {
    console.log(req.body);
    console.log(3);     //用于测试执行顺序
    res.send('ok');
})

app.listen(8080, () => {
    console.log('express server running http://127.0.0.1:8080')
})

上面代码打印结果:

1
2
[Object: null prototype] { name: 'lk', age: '20', gender: '男' }
3

问题:如图所示,next()函数是放在监听data事件中的,为什么不放在①处(监听事件外)?

答:因为req.on监听事件是一个异步函数,如果把next()放在监听事件外面,异步函数还没执行就next(),程序就会先执行后面的路由或中间件了,最后再执行异步任务。这样打印的结果变为

undefined
3
1
2

总结

有问题可以私信或评论。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 使用异步函数是不会逃脱 express app.use 函数的捕获错误机制的。 在 express ,app.use 函数用于添加间件函数,这些函数会在请求和响应的生命周期被调用。如果在这些函数抛出了错误,那么 express 会捕获这个错误并将其传递给错误处理间件。 因此,无论是同步函数还是异步函数,都不会逃脱 express app.use 函数的捕获错误机制。如果你在 app.use 函数使用了异步函数,那么只需要在函数内部使用 try-catch 语句或者在函数最后使用 await 来捕获并处理异步操作可能出现的错误即可。 ### 回答2: 在Express,通过app.use函数注册的间件会自动捕获发生在其内部的同步错误,并通过next函数将错误传递给错误处理间件进行处理。这种错误捕获机制可以有效地处理同步错误。然而,对于异步函数Express的错误处理机制是无法自动捕获并处理的。 使用异步函数时,如果在异步函数内部发生错误,Express的错误处理机制将无法捕获到这些错误,也无法进行相应的处理。这是因为异步函数的执行是非阻塞的,它们会立即返回一个Promise对象,并在后台执行。在这种情况下,错误发生在异步函数内部,而Express的错误处理机制在异步函数返回Promise对象后已经无法获取到这些错误。 为了解决这个问题,我们可以使用try/catch语句来捕获异步函数内部的错误,并手动调用next函数传递错误。这样,错误将被传递到下一个错误处理间件进行处理。 示例代码如下: app.use(async (req, res, next) => { try { // 异步操作 await someAsyncFunction(); next(); } catch (err) { next(err); } }); 上述代码,我们使用了async/await语法来处理异步函数,然后在try块执行异步操作,如果发生错误,则通过next函数将错误传递给下一个错误处理间件进行处理。 综上所述,使用异步函数时,需要手动处理其发生的错误,通过try/catch语句捕获错误并调用next函数传递错误,以便Express能够正确地处理它们。 ### 回答3: 使用异步函数不会逃脱express`app.use`函数的捕获错误的机制。 在Express,通过定义间件函数来处理HTTP请求,这些间件函数可以是同步的,也可以是异步的。无论是同步还是异步的间件函数Express都会在调用它们时使用try-catch块来捕获可能出现的错误。 在异步函数,当出现错误时,如果没有使用try-catch语句来显式地捕获错误,这些错误将会被自动转发到错误处理间件。错误处理间件是一个专门用来处理错误的间件函数,可以用`app.use`或`app.use(errorHandler)`方式来定义。因此,无论是同步的还是异步的函数,只要在处理请求的过程出现错误,Express都会通过错误处理间件来捕获和处理这些错误。 例如,下面是一个使用异步函数Express间件的示例: ``` app.use(async (req, res, next) => { try { // 异步操作 await someAsyncFunction(); // 继续处理请求 next(); } catch (err) { // 错误处理 next(err); } }); ``` 在上述示例,`someAsyncFunction`是一个异步函数,当它抛出一个错误时,try-catch块会捕获这个错误并通过`next(err)`将其传递给错误处理间件进行处理。 总之,无论使用同步还是异步函数Express都会捕获这些函数可能抛出的错误,并通过错误处理间件来处理这些错误,使得我们能够更好地处理和管理错误。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值