Что такое эквивалент Spring Boot Webflux библиотеки Morgan JS?

В Javascript есть замечательная библиотека Морган, которая регистрирует все входящие HTTP-запросы. Интересно, есть ли эквивалентная библиотека в Java/Kotlin для регистрации запросов весенней загрузки webflux.

Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
0
0
135
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вот что у меня сработало после просмотра этого репо

Я всю ночь пытался получить тело запроса, но продолжал получать ошибки: один подписчик только для каждого запроса. Это либо невозможно, либо чертовски сложно, либо не рекомендуется в случае запросов с большим телом (поскольку это может заблокировать ваш сервер). Поэтому я настоятельно рекомендую вместо этого преобразовать ваши @RequestBody объекты в @RequestParam параметры запроса, если вы хотите регистрировать переменные в почтовых запросах.

package com.example.demo

import org.slf4j.LoggerFactory
import org.springframework.stereotype.Component
import org.springframework.web.server.ServerWebExchange
import org.springframework.web.server.WebFilter
import org.springframework.web.server.WebFilterChain
import reactor.core.publisher.Mono


@Component
class LogFilter: WebFilter {

    private val logger = LoggerFactory.getLogger(LogFilter::class.java)

    override fun filter(exchange: ServerWebExchange, chain: WebFilterChain): Mono<Void> {
        val startTime = System.currentTimeMillis()
        val request = exchange.request
        val path = request.uri.path

        val requestPrintMap = mutableMapOf<Any, Any>()
        requestPrintMap["headers"] = request.headers
        requestPrintMap["uri"] = request.uri
        requestPrintMap["params"] = request.queryParams

        return chain
                .filter(exchange)
                .doAfterTerminate {

            logger.info("Served '{}' as {} in {} msec",
                    path,
                    exchange.response.statusCode,
                    System.currentTimeMillis() - startTime)
        }
    }

}

Другие вопросы по теме