package com.kidgrow.common.filter; import cn.hutool.core.util.StrUtil; import com.kidgrow.common.constant.CommonConstant; import com.kidgrow.log.properties.TraceProperties; import org.slf4j.MDC; import org.springframework.boot.autoconfigure.condition.ConditionalOnClass; import org.springframework.web.filter.OncePerRequestFilter; import javax.annotation.Resource; import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.ServletException; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; /** * 石家庄喜高科技有限责任公司 版权所有 © Copyright 2020
* * @Description: 日志跟踪过滤器
* @Project:
* @CreateDate: Created in 2020/2/27 14:57
* @Author: liuke */ @ConditionalOnClass(Filter.class) public class TraceFilter extends OncePerRequestFilter { @Resource private TraceProperties traceProperties; @Override protected boolean shouldNotFilter(HttpServletRequest request) { return !traceProperties.getEnable(); } @Override protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws IOException, ServletException { try { String traceId = request.getHeader(CommonConstant.TRACE_ID_HEADER); if (StrUtil.isNotEmpty(traceId)) { MDC.put(CommonConstant.LOG_TRACE_ID, traceId); } filterChain.doFilter(request, response); } finally { MDC.clear(); } } }