Compartilhamento de tecnologia

Imprima logs através do gateway para controlá-los globalmente

2024-07-11

한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina

precisar:

As empresas geralmente precisam imprimir logs. O código tradicional mais os logs são muito intrusivos para o código. Independentemente de adicionar, excluir ou modificar o log, o código será alterado, mesmo que as anotações sejam usadas. para conseguir isso, adicione código sem qualquer intrusão.

Solução

filtro personalizado de gateway.
Pré-requisito, o gateway foi usado no projeto.

código


import lombok.extern.slf4j.Slf4j;
import org.springframework.cloud.gateway.filter.GatewayFilterChain;
import org.springframework.cloud.gateway.filter.GlobalFilter;
import org.springframework.core.Ordered;
import org.springframework.stereotype.Component;
import org.springframework.web.server.ServerWebExchange;
import reactor.core.publisher.Mono;
@Component
@Slf4j
public class MyGlobalFilter implements GlobalFilter, Ordered
{

    /**
     * 数字越小优先级越高
     * @return
     */
    @Override
    public int getOrder()
    {
        return 0;
    }

    private static final String BEGIN_VISIT_TIME = "begin_visit_time";//开始访问时间
    /**
     *第2版,各种统计
     * @param exchange
     * @param chain
     * @return
     */
    @Override
    public Mono