当前位置:  首页  >  PHP资讯  >  业界资讯

SpringCloudZuul添加过滤器过程解析

这篇文章主要介绍了SpringCloudZuul添加过滤器过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

这篇文章主要介绍了Spring Cloud Zuul添加过滤器过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

Zuul作为网关的其中一个重要功能,就是实现请求的鉴权。而这个动作我们往往是通过Zuul提供的过滤器来实现的。

一、过滤器方法的作用

想要使用Zuul实现过滤功能,我们需要自定义一个类继承ZuulFilter类,并实现其中的四个方法,我们先看一下这四个方法的作用是什么

 public class MyFilter extends ZuulFilter { /** * filterType:返回字符串,代表过滤器的类型。包含以下4种: * -- pre:请求在被路由之前执行 * -- route:在路由请求时调用 * -- post:在route和errror过滤器之后调用 * -- error:处理请求时发生错误调用 * @return 返回以上四个类型的名称 */ @Override public String filterType() { return null; } /** * filterOrder:通过返回的int值来定义过滤器的执行顺序,数字越小优先级越高。 * @return */ @Override public int filterOrder() { return 0; } /** * shouldFilter:返回一个Boolean值,判断该过滤器是否需要执行。返回true执行,返回false不执行。 * @return */ @Override public boolean shouldFilter() { return false; } /** * run:编写过滤器的具体业务逻辑。 * @return * @throws ZuulException */ @Override public Object run() throws ZuulException { return null; } }

二、自定义过滤器

我这里以pre类型演示

 @Component public class LoginFilter extends ZuulFilter { //过滤类型 pre route post error @Override public String filterType() { return "pre"; } //过滤优先级,数字越小优先级越高 @Override public int filterOrder() { return 10; } //是否执行run方法 @Override public boolean shouldFilter() { return true; } //过滤逻辑代码 @Override public Object run() throws ZuulException { //获取zuul提供的上下文对象 RequestContext cOntext= RequestContext.getCurrentContext(); //获取request对象 HttpServletRequest request = context.getRequest(); //获取请求参数 String token = request.getParameter("username"); //判断 if (StringUtils.isBlank(username)){ //过滤该请求,不对其进行路由 context.setSendZuulResponse(false); //设置响应码401 context.setResponseStatusCode(HttpStatus.SC_UNAUTHORIZED); //设置响应体 context.setResponseBody("request error...."); } // 校验通过,把登陆信息放入上下文信息,继续向后执行 context.set("username",username); return null; } }

没添加过滤功能之前是这样的 ↓,无论加不加username都可以得到数据

添加了过滤功能之后是这样的 ↓,只有加了username才能访问

F12打开控制台,发现响应了401

三、过滤器执行的声明周期

过滤器执行的声明周期

正常流程:

请求到达首先会经过pre类型过滤器,而后到达route类型,进行路由,请求就到达真正的服务提供者,执行请求,返回结果后,会到达post过滤器。而后返回响应。

异常流程:

整个过程中,pre或者route过滤器出现异常,都会直接进入error过滤器,在error处理完毕后,会将请求交给POST过滤器,最后返回给用户。

如果是error过滤器自己出现异常,最终也会进入POST过滤器,将最终结果返回给请求客户端。

如果是POST过滤器出现异常,会跳转到error过滤器,但是与pre和route不同的是,请求不会再到达POST过滤器了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

内容推荐:免费高清PNG素材下载
吐了个 "CAO" !
扫码关注 PHP1 官方微信号
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved PHP1.CN 第一PHP社区 版权所有 京ICP备19059560号-4