Zuul-自定义Filter

自定义过滤器

         实现过滤器很简单,只需要继承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

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值