Zuul中RequestContext.setSendZuulResponse的心得

自从项目使用微服务以后,很多以前在业务端实现的功能,如限流,加密,身份认证等,就搬到了Zuul中,这之间也走了很多弯路,最近打算将使用过程中的一些心得体会慢慢写下来,沉淀一下

ZuulFilter中的RequestContext.setSendZuulResponse这个方法在几乎每个教程中都会有涉及,但是大多数教程都没有讲清楚其作用,只是一句"ctx.setSendZuulResponse(false) 表示不进行路由",其具体意思不太明白,后来经过尝试发现,将其设为false代表的意思是,这个请求最终不会被zuul转发到后端服务器,但是如果当前Filter后面还存在其他Filter,那么其他Filter仍然会被调用到,所以一般我们在Filter的shouldFilter方法中,都会通过


  
  
  1. @Override
  2. public boolean shouldFilter() {
  3. RequestContext ctx = RequestContext.getCurrentContext();
  4. if(!ctx.sendZuulResponse()){
  5. return false;
  6. }
  7. }

这样的方法来做判断,如果这个请求最终被拦截掉,则后面的过滤器逻辑也不需要执行了

实际用的时候是context.setSendZuulResponse(false)

发布了74 篇原创文章 · 获赞 0 · 访问量 4703

猜你喜欢

转载自blog.csdn.net/qq_44813090/article/details/104307509
今日推荐