1. 使用HandlerInterceptor时候,注意如果你在pre阶段做了值填充,注意在filter中进行删除,不然抛出异常会, threadlocal信息又没有被删除,在Tomcat中线程复用,拿到错误请求的threadlocal信息,获取的信息有问题,这里面异常情况注意是不会走 afterCompletion,你如果在这里进行删除threadlocal就不行,需要在dofilter方法下执行就可以,比如按照这种方式:https://github.com/spring-projects/spring-boot/blob/b3597107bab903d3c0012d0279a240aeefe6e25b/spring-boot/src/main/java/org/springframework/boot/context/web/ErrorPageFilter.java
2.使用threadlocal使用
public class ThreadUtil {
public static ThreadLocal<String> REQUEST_ID = new ThreadLocal<>();
public static void set(String value) {
REQUEST_ID.set(value);
}
public static String get() {
return REQUEST_ID.get();
}
public static void clean() {
if (REQUEST_ID != null) {
REQUEST_ID.remove();
}
}
}