自定义过滤器
实现过滤器很简单,只需要继承ZuulFilter,并实现ZuulFilter中的抽象方法。其中filterType()和filterOrder(),以及IZuulFilter的shouldFilter()和Object run()的两个方法。
- filterType():定义过滤器的类型,它有4种类型,分别是pre、post、routing和error
- filterOrder():过滤顺序,它是一个Int类型的值,值越小,越早执行该过滤器
- shouldFilter():表示该过滤器是否过滤逻辑,如果为true,则执行run方法,如果为false,则不执行run方法
- Object run():写具体的过滤逻辑
展示一个简单的例子,判断请求的参数中是否有token这个参数,如果没有传,则请求不会被路由到具体的服务实例,直接返回响应,代码如下:
@Component
public class MyZuulFilter extends ZuulFilter {
@Override
public String filterType() {
return "pre";
}
@Override
public int filterOrder() {
return 1;
}
@Override
public boolean shouldFilter() {
return true;
}
@Override
public Object run() throws ZuulException {
RequestContext context=RequestContext.getCurrentContext();
HttpServletRequest request=context.getRequest();
Object accessToken=request.getParameter("token");
if (null==accessToken)
{
context.setSendZuulResponse(false);
context.setResponseStatusCode(404);
try {
context.getResponse().getWriter().write("token is empty");
}catch (Exception e) { }
return null;
}
return null;
}
}
启动服务,打开浏览器访问:http://127.0.0.1:8777/hello/hello/yang,浏览器显示:
token is empty
访问http://127.0.0.1:8777/hello/hello/yang?token=111,浏览器显示:
hello!yang======端口号:8763
可见MyFilter这个Bean在注入到Ioc容器后,对请求进行了过滤,并在请求路由转发之前进行了逻辑判断。
禁用过滤器
只需要在application.properties(或yml)中配置需要禁用的filter,格式为:zuul.[filter-name].[filter-type].disable=true
。如:
zuul.FormBodyWrapperFilter.pre.disable=true