Zuul作为网关服务,是其他各服务对外中转站,通过Zuul进行请求转发。这就涉及到部分数据是不能原封返回的,比如服务之间通信的凭证,用户的加密信息等等。举个例子,用户服务提供一个登录接口,用户名密码正确后返回一个Token,此Token作为用户服务的通行证,那么用户登录成功后返回的Token就需要进行加密或者防止篡改处理。在到达用户服务其他接口前,就需要对Token进行校验,非法的Token就不需要转发到用户服务中了,直接在网关层返回信息即可。要修改服务返回的信息,需要使用的是Zuul的过滤器。使用时只需要继承ZuulFilter,实现必要的方法即可。Zuul提供默认的四种过滤器类型,通过filterType方法进行标识。关于Zuul过滤器的执行过程,这里不需要多说明,源码一看便知,ZuulServletFilter:方法说明:

详解SpringCloud Zuul过滤器返回值拦截

详解SpringCloud Zuul过滤器返回值拦截

详解SpringCloud Zuul过滤器返回值拦截