问题描述:由于是通过RequestContextHolder获取的请求头,RequestContextHolder又是使用的ThreadLocal 去保存的请求头,所以换了个线程就获取不到了。
ServletRequestAttributes servletRequestAttributes = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes());
HttpServletRequest request=servletRequestAttributes.getRequest();
解决方法:直接将request作为入参,传递给异步方法。异步方法就能够直接拿到request。
HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
logService.asyncSaveSystemLog(request,platform, bussinessName);//这行代码是异步执行的
由于logService.asyncSaveSystemLog里面多出用到了自定义的RequestUtil。RequestUtil工具类都是通过RequestContextHolder去获取的相关信息的,而工具类又不想调整。所以logService.asyncSaveSystemLog方法就多做了一步,将request直接放入RequestContextHolder。
RequestContextHolder.setRequestAttributes(new ServletRequestAttributes(request));