0

我正在尝试将所有入站请求记录到我的数据库中。为此,我创建了一个中间件,在其中我使用数据触发一个事件,然后是一个处理数据并将其保存在数据库中的侦听器。

我可以记录所有请求信息,但无法记录响应信息。

这是我的中间件:

'use strict'
/** @typedef {import('@adonisjs/framework/src/Request')} Request */
/** @typedef {import('@adonisjs/framework/src/Response')} Response */
/** @typedef {import('@adonisjs/framework/src/View')} View */
const Event = use('Event')

class InboundRequestLogger {
    /**
     * @param {object} ctx
     * @param {Request} ctx.request
     * @param {Response} ctx.response
     * @param {Function} next
     */
    async handle({request, response}, next) {

        Event.fire('new::inboundRequest', {
            'method': request.method(),
            'url': request.originalUrl(),
            'ip': request.ip(),
            'headers': request.headers(),
            'body': request.all(),
            'is_ajax': request.ajax()
        })

        // call next to advance the request
        await next()
    }
}

module.exports = InboundRequestLogger

问题是我不知道如何触发next()然后检查响应(例如状态码)。

我试过这样做:

class MyMiddleware {
    async handle (ctx, next) {
        await next()
        ctx.response.response.on('finish', () => {
          console.log(ctx.response.response.statusCode)
        })
    }
}

但是之后什么都没有发生await next()

如何在此中间件中获取响应内容?

阿多尼斯版本:4.1

4

1 回答 1

0

结束事件处理程序应该在调用下一个之前放置

 ctx.response.response.on('finish', () => {
     console.log(ctx.response.response.statusCode)
 })
 await next()
于 2020-08-17T08:35:40.603 回答