业务场景:定时任务中通过fegin接口调用其他服务的接口进行业务的处理
1.在fegin配置文件中回爆空指针异常
2.原因分析:
3.定时任务在项目启动的时候就会执行,导致request为空
异步调用
异步调用是相对同步调用而言,同步调用指的是程序按照指令一步步执行,每一步都必须等待上一步执行完成后才可以执行,同步调用具有依赖性,而异步调用无需等待上一步执行完成便可以执行,即异步调用不依赖上一步操作,所有可以并发执行.
4.解决方式
相关包
@Configuration
public class FeignConfiguration implements RequestInterceptor {
@Override
public void apply(RequestTemplate template) {
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder
.getRequestAttributes();
if (attributes == null) {
RequestContextHolder.setRequestAttributes(new ServletRequestAttributes(new MockHttpServletRequest()));//为空进行新建
attributes = (ServletRequestAttributes) RequestContextHolder
.getRequestAttributes();//重新赋值
}
HttpServletRequest request = attributes.getRequest();
// 对消息头进行配置
Enumeration<String> headerNames = request.getHeaderNames();
if (headerNames != null) {
/**
* 判断有没有token,如果是定时任务进来,是没有token的,此时用默认token以调用到对应的Feign服务
*/
boolean flag = true;
while (headerNames.hasMoreElements()) {
String name = headerNames.nextElement();
String values = request.getHeader(name);
if(name.equals("token")){
flag = false;
}
template.header(name, values);
}
if(flag){
template.header("token","!@#$%^&*()Cid6032001_Feign");
}
}
// 对请求体进行配置
Enumeration<String> bodyNames = request.getParameterNames();
StringBuffer body =new StringBuffer();
if (bodyNames != null) {
while (bodyNames.hasMoreElements()) {
String name = bodyNames.nextElement();
String values = request.getParameter(name);
body.append(name).append("=").append(values).append("&");
}
}
if(body.length()!=0) {
body.deleteCharAt(body.length()-1);
template.body(body.toString());
}
}
}