Spring Cloud学习--服务网关(Zuul 过滤器)

本文目录:

一. 过滤器类型和生命周期:

Zuul的核心组件是过滤器,Zuul中定义了4种过滤器类型:

  • pre:在请求被路由之前调用。我们可利用这种过滤器实现身份验证、在集群中选择请求的微服务、记录调试信息等。

  • routing:在路由请求时候被调用。这种过滤器用于构建发送给微服务的请求,并使用Apache HttpClient或Netfilx Ribbon请求微服务。

  • post:在routing和error过滤器之后被调用。这种过滤器可用来为响应添加标准的HTTP Header、收集统计信息和指标、将响应从微服务发送给客户端等。

  • error:在其他阶段发生错误时被调用。

Zuul请求的生命周期如图所示,该图详细的描述了各种类型的执行顺序。

Zuul请求生命周期

二. 编写Zuul过滤器

编写Zuul过滤器类,只需要继承ZuulFilter,实现其抽象方法即可。

public class PreRequestFilter extends ZuulFilter{

    private final static Logger LOGGER = LoggerFactory.getLogger(PreRequestFilter.class);

    @Override
    public String filterType() {
        return "pre";
    }

    @Override
    public int filterOrder() {
        return 0;
    }

    @Override
    public boolean shouldFilter() {
        return true;
    }

    @Override
    public Object run() {
        HttpServletRequest servletRequest = RequestContext.getCurrentContext().getRequest();
        String host = servletRequest.getRemoteHost();
        PreRequestFilter.LOGGER.info("request host : " + host);
        return null;
    }
}

自定义的ZuulFilter 需要实现以上四个方法:

filterType:返回过滤器的类型,有pre、route、post和error等4种类型。
filterOrder:返回一个int值,指定过滤器的执行顺序。
shouldFilter:返回有个boolean值,判断该过滤器是否执行。
run:过滤器的具体逻辑。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值