我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么为Spring Cloud Gateway加上全局过滤器

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么为Spring Cloud Gateway加上全局过滤器

本篇内容介绍了“怎么为Spring Cloud Gateway加上全局过滤器”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

既然是一个网关。那么全局过滤器肯定是少不了的一个存在。像是鉴权、认证啥的不可能每个服务都做一次,一般都是在网关处就搞定了。
Zuul他就有很强大的过滤器体系来给人使用。
Gateway当然也不会差这么点东西。
对于SpringCloud体系来说,一切的实现都是那么的简单。那么废话不多说,直接开始写起来。
 
Gateway内部有一个接口 名为GlobalFilter,这个就是Gateway的全局过滤器接口,只要在应用中实现此接口后注册为Spring的Bean,背后就会帮你将这个实现注册到全局过滤器链条里边去。
我这里就简单的写了个模拟鉴权的过滤器实现:

@Componentpublic class AuthFilter implements GlobalFilter, Ordered {  @Override  public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {    String token = exchange.getRequest().getHeaders().getFirst("Authorization");    //不为空则通过    if (!StringUtils.isEmpty(token)) return chain.filter(exchange);    ServerHttpResponse response = exchange.getResponse();    // 封装错误信息    Map<String, Object> responseData = Maps.newHashMapWithExpectedSize(3);    responseData.put("code", HttpStatus.UNAUTHORIZED.value());    responseData.put("message", "Token is empty");    responseData.put("cause", "Token is empty");    // 将信息转换为 JSON    ObjectMapper objectMapper = new ObjectMapper();    byte[] data = new byte[0];    try {      data = objectMapper.writeValueAsBytes(responseData);    } catch (JsonProcessingException e) {      e.printStackTrace();    }    // 返回错误信息json    DataBuffer buffer = response.bufferFactory().wrap(data);    response.setStatusCode(HttpStatus.UNAUTHORIZED);    response.getHeaders().add("Content-Type", "application/json;charset=UTF-8");    return response.writeWith(Mono.just(buffer));  }  //最后执行  @Override  public int getOrder() {    return Ordered.LOWEST_PRECEDENCE;  }}

虽说是鉴权,但实际上我这就是个简单的demo而已。想知道真正的Spring Security鉴权/认证怎么写?
我以前写的这个:https://github.com/skypyb/code_demo/tree/master/spring-security-demo 应该可以帮助你。
 
看我写的这个过滤器内部实现哈,其实就是拿出Request Header中的 Authorization字段(token) 然后判断是否存在。不存在就返回错误,存在就交给链条中的下一个过滤器。
 
过滤器其实也没啥好说的,那么说说限流。
关于限流这个东西,常见的算法就是漏桶和令牌桶了,对于一个应用单机限流来说也复杂不到哪儿去。
靠着google guava包里的RateLimiter工具都能搞定大多数场景了。
不过既然人家Gateway好心好意给你搞了个限流的实现。那么还是尊重他用一下。
由于Gateway是用的Redis和lua脚本实现了令牌桶的算法,那么先导入几个需要的依赖:

<!--Redis begin-->    <dependency>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-starter-data-redis</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-starter-data-redis-reactive</artifactId>    </dependency>    <dependency>      <groupId>redis.clients</groupId>      <artifactId>jedis</artifactId>    </dependency>    <!--Redis end-->

既然是Redis,那还是先配一下Redis序列化先:

@Configurationpublic class RedisConfig {  @Bean  public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory connectionFactory) {    RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();    StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();    redisTemplate.setKeySerializer(stringRedisSerializer);    redisTemplate.setHashKeySerializer(stringRedisSerializer);    redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer<Object>(Object.class));    redisTemplate.setHashValueSerializer(new GenericJackson2JsonRedisSerializer());    redisTemplate.setConnectionFactory(connectionFactory);    return redisTemplate;  }}

万事俱备,开始进行限流的具体实现了。
 
既然是限流,那么也得有个限流策略
是根据用户来限流呢?还是说根据请求路径限流?或者是IP限流?
不过这个都是由需求来决定了,我这就简单的写个根据IP来限流的。
人家也给你封装完毕了,只需要你自己实现KeyResolver这个接口就可以。
由于实现这个一般来说也就一行代码,所以我就不写个单独的类去实现了,而是直接写在配置类里边。

@Configurationpublic class GatewayRateLimiterConfig {    @Bean(value = "ipKeyResolver")  public KeyResolver ipKeyResolver() {    return exchange -> Mono.just(exchange.getRequest().getRemoteAddress().getAddress().getHostAddress());  }}

看,我其实只需要返回我需要限制的东西就可以了。我这里提取到用户的IP将其返回,即可实现通过ip来进行限流的策略。
不过限流相关的配置写了,那也得用起来。
这个怎么用起来? 其实直接在配置文件里配置就OK了

spring: application:  # 应用名称  name: sc-demo-alibaba-gateway cloud:  nacos:   discovery:    server-addr: 192.168.3.105:8848 #注册进nacos  # 使用 Sentinel 作为熔断器  sentinel:   transport:    port: 18102    dashboard: 192.168.3.105:8858  # 路由网关配置  gateway:   # 这里是设置与服务注册发现组件结合,这样可以采用服务名的路由策略   discovery:    locator:     enabled: true   # 配置路由规则   routes:    - id: ROUTER#sc-demo-alibaba-consumer #这个是路由ID,需要保证在所有路由定义中唯一,值随便写就是了     # 采用 LoadBalanceClient 方式请求,以 lb:// 开头,后面的是注册在 Nacos 上的服务名     uri: lb://sc-demo-alibaba-consumer     predicates:      # Method ,这里是匹配 GET 和 POST 请求      - Method=GET,POST     filters:      - name: RequestRateLimiter       args:        redis-rate-limiter.burstCapacity: 20        redis-rate-limiter.replenishRate: 5        key-resolver: '#{@ipKeyResolver}'    - id: ROUTER#sc-demo-alibaba-provider     uri: lb://sc-demo-alibaba-provider     predicates:      - Method=GET,POST #Redis配置 redis:  host: 192.168.3.105  port: 6379  #Redis连接池配置  jedis:   pool:    min-idle: 0    max-idle: 8    max-active: 8    max-wait: -1msserver: port: 8888feign: sentinel:  enabled: truemanagement: endpoints:  web:   exposure:    include: "*"# 配置日志级别,方别调试logging: level:  org.springframework.cloud.gateway: debug

这里可以看到,除了Redis配置 ( spring.redis.** )以外。
主要就是对于Getway的配置。
在Gateway路由配置中,设置了一个filters参数。
这个是为了指定路由的各种过滤器的。这个参数也有很多种,可以参考官方讲解: https://cloud.spring.io/spring-cloud-gateway/2.0.x/single/spring-cloud-gateway.html#gateway-route-filters

我这就是指定了一个RequestRateLimiter,请求限流。

  • redis-rate-limiter.burstCapacity: 20     

这个参数表示突发容量,即每秒可以最大通过多少次请求

  • redis-rate-limiter.replenishRate: 5      

 这个是令牌桶的补充速度,每秒往桶里边放几个令牌

  • key-resolver: ‘#{@ipKeyResolver}'             

这个就是用上KeyResolver的具体实现了,这里用spel表达式指定我写的那个ip限制类

准备好之后将应用启动就完事了,想测的话可以用jmeter测测看,或者将请求限制写的更小一点,在网页上狂按f5也行。

“怎么为Spring Cloud Gateway加上全局过滤器”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎么为Spring Cloud Gateway加上全局过滤器

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么为Spring Cloud Gateway加上全局过滤器

本篇内容介绍了“怎么为Spring Cloud Gateway加上全局过滤器”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!既然是一个网关。那
2023-06-14

vue全局过滤器怎么设置(教程)

Vue.js 全局过滤器教程Vue.js 是一个高效、灵活并且易于学习的前端框架,具有响应式和组件化的特性。Vue.js 还提供了一种很便捷的方式来处理数据,那就是 Vue.js 的过滤器。在 Vue.js 中,过滤器可以用于转换数据。通常我们要将数据进行格式化以满足应用程序的需求,比如日期格式化、货币格式化等。在 Vue.js 中,全局过滤器可以被注册,以便在应用程序的任何部
2023-05-14

Matplotlib怎么为图表添加交云端算法控过滤器

要为Matplotlib图表添加交云端算法控过滤器,可以使用widgets模块中的interact函数。这个函数可以创建一个交互式控件,让用户可以通过滑块、文本框等方式来动态调整图表的参数。下面是一个简单的示例代码,演示如何使用inter
Matplotlib怎么为图表添加交云端算法控过滤器
2024-05-21

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录