springcloud- FeginClient 调用统一拦截添加请求头 RequestInterceptor ,被调用服务获取请求头...

使用场景:

  在springcloud中通过Fegin调用远端RestApi的时候,经常需要传递一些参数信息到被调用服务中去,比如从A服务调用B服务的时候,
  需要将当前用户信息传递到B调用的服务中去,我们就可以使用实现 RequestInterceptor接口,完成FeginClient 请求调用时拦截请求的统一处理请求头,添加请求头信息等;

@Slf4j
@Component
public class DtsInterceptor implements RequestInterceptor {

    @Override
    public void apply(RequestTemplate requestTemplate) {
         //TODO 做一些业务处理,获取数据,添加数据到请求头
         requestTemplate.header(key,value);
    }
}

 在被调用服务中获取请求头

 第一种方式:

HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
try {
    request.setCharacterEncoding(“UTF-8”);
} catch (UnsupportedEncodingException e1) {
    e1.printStackTrace();
}
String sUserInfo = request.getHeader(KEY);

第二种方式:

 配置Spring MVC的拦截器(Interceptor),可以自定义实现HandlerInterceptor接口,也可以通过继承HandlerInterceptorAdapter类,后者是前者的实现类。

 

public class UserInterceptor extends HandlerInterceptorAdapter {

    /** 预处理回调方法,实现处理器的预处理(如登录检查)。
     * 第三个参数为响应的处理器,即controller。
     * 返回true,表示继续流程,调用下一个拦截器或者处理器。
     * 返回false,表示流程中断,通过response产生响应。
     *
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        String key = request.getHeader("key");
        if(StringUtils.isNotBlank(key)){
            return false ;
        }else {
            //TODO 解析key为用户信息,解析成功返回true,解析失败返回false
            return true ;
        }
    }


    /**
     *当前请求进行处理之后,也就是Controller 方法调用之后执行,
     *但是它会在DispatcherServlet 进行视图返回渲染之前被调用。
     *此时我们可以通过modelAndView对模型数据进行处理或对视图进行处理。
*/
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        super.postHandle(request, response, handler, modelAndView);
    }

    /**
     *方法将在整个请求结束之后,也就是在DispatcherServlet 渲染了对应的视图之后执行。
     *这个方法的主要作用是用于进行资源清理工作的。
     */
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        super.afterCompletion(request, response, handler, ex);
    }

 

为了使自定义的拦截器生效,需要注册拦截器到spring容器中,具体的做法是继承 WebMvcConfigurerAdapter类,覆盖其 addInterceptors(InterceptorRegistry registry)方法。最后别忘了把Bean注册到Spring容器中,可以选择@Component 或者 @Configuration。

 

@Component
public class InterceptorConfiguration extends WebMvcConfigurerAdapter {

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        // 注册拦截器
        InterceptorRegistration interceptorRegistration = registry.addInterceptor(new UserInterceptor());
        // 配置拦截的路径
        interceptorRegistration.addPathPatterns("/**");
        // 配置不拦截的路径
        interceptorRegistration.excludePathPatterns("/**.html");
        // 还可以在这里注册其它的拦截器
        // registry.addInterceptor(new OtherInterceptor()).addPathPatterns("/**");
      super.addInterceptors(registry);
    }
}

 

转载于:https://www.cnblogs.com/wenq001/p/9132118.html

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值