过滤器
Zuul作为网关的其中一个重要功能,就是实现请求的鉴权。而这个动作往往是通过Zuul提供的过滤器实现的。
ZuulFilter
ZuulFilter是过滤器的顶级父类。其中最重要的四个方法:
public abstract ZuulFilter implements IZuulFilter{ abstract public String filterType(); abstract public int filterOrder(); boolean shouldFilter();// 来自IZuulFilter Object run() throws ZuulException;// IZuulFilter }
shouldFilter:返回一个Boolean值,判断该过滤器是否执行。返回true执行,返回false不执行。
run:过滤器的业务具体逻辑。
filterType:返回字符串,代表过滤器的类型。包含以下四种:
pre:请求在被路由之前执行。
route:在路由请求时调用。
post:在route和error过滤器之后调用。
error:处理请求发生错误时调用。
FilterOrder:通过返回的int值来定义过滤器的执行顺序、数字越小优先级越高。
扫描二维码关注公众号,回复:
10789843 查看本文章
过滤器执行生命周期
正常流程:
请求到达后首先会经过pre类型过滤器,然后到达route类型,进行路由,请求到达真正的服务提供者,执行请求,返回结果,到达post过滤器,最后返回响应。
异常流程:
整个过程中,pre或者route过滤器出现异常,都会直接进入error过滤器,在error处理完毕后,会将请求交给post过滤器,最后返回给用户。
如果是error过滤器自己出现了异常,最终也会进入post过滤器,将最终结果返回给用户。
如果是post过滤器出现了异常,会跳转到error过滤器,但是请求不会再到达post过滤器,直接将最终结果返回给用户。
使用场景
请求鉴权:一般放在pre类型,如果发现没有访问权限,就直接进行拦截。
异常处理:一般会放在error类型和post类型过滤器中结合使用。
服务调用时长统计:pre和post结合使用。