技術共有

ゲートウェイ経由でログを印刷し、ログをグローバルに制御します

2024-07-11

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

必要:

ビジネスではログを出力する必要があることがよくありますが、ログの追加、削除、変更に関わらず、コードに煩わしさがあり、必要に応じてコードを追加する必要があります。これを達成するには、何の侵入もせずにコードを追加します。

解決

ゲートウェイのカスタムフィルター。
前提条件として、プロジェクトでゲートウェイが使用されています。

コード


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