SpringCloud Gateway网关路由配置 接口统一 登录验证 权限校验 路由属性

介绍

Spring Cloud Gateway 根据请求的路径、HTTP 方法、头部等信息,将请求路由到对应的微服务实例。它支持基于动态路由规则的配置,可以根据请求的 URL、查询参数、请求头等条件,灵活地决定将请求转发到哪个微服务。Spring Cloud Gateway 提供了一个单一的入口点,所有来自客户端的请求都通过该网关进行转发。通过这种方式,外部应用无需直接访问各个微服务,提高了架构的可维护性和安全性。

网关也是一个微服务

依赖

xml 复制代码
 <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-gateway</artifactId>
        <version>3.1.4</version>
        <!-- 对应 Spring Cloud 2021.0.4 版本 -->
    </dependency>

其他配合依赖

xml 复制代码
<!--负载均衡-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-loadbalancer</artifactId>
    <version>3.1.3</version>  <!-- Spring Cloud OpenFeign 版本 -->
</dependency>

<!--  nacos 服务的注册发现     -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    <version>2021.0.5.0</version>
</dependency>

配置文件

yml 复制代码
server:
  port: 80
spring:
  application:
    name: gateway #服务名称
  cloud:
    nacos:
      server-addr: 172.23.4.128:8848 #注册中心

路由配置

yml 复制代码
server:
  port: 80
spring:
  application:
    name: gateway #服务名称
  cloud:
    nacos:
      server-addr: 172.23.4.128:8848 #注册中心
    gateway:
      routes:
        - id: java-user #路由ID 一般为服务名称
          uri: lb://java-user #转发的路径 lb为负载均衡 java-user为服务接口
          predicates: #路由条件
            - Path=/user/** #请求接口路径
            # - Path=/user/**,/path/**    多个控制器这样写
        - id: java-goods
          uri: lb://java-goods
          predicates:
            - Path=/goods/**

这样就可以通过127.0.0.1:80/user/xxx/ 将请求负载均衡到其他微服务上了


路由属性

  • id 路由的唯一标识符
  • uri 路由的目标地址
  • predicates 路由断言,判断请求是否符合当前路由。
  • filter 路由过滤器,对请求或响应做特殊处理

路由断言

路由过滤器

添加请求头

token为请求头名称,123456为值

yml 复制代码
gateway:
  routes:
    - id: java-user #路由ID 一般为服务名称
      uri: lb://java-user #转发的路径 lb为负载均衡 java-user为服务接口
      predicates: #路由条件
        - Path=/user/** #请求接口路径
        # - Path=/user/**,/path/**    多个控制器这样写
    - id: java-goods
      uri: lb://java-goods
      predicates:
        - Path=/goods/**
        
      filters:
        - AddRequestHeader=token,123456

如果微服务的接口很多,每个服务但需要去配置filters就特别麻烦,可以配置全局的请看下方。

微服务获取请求头

java 复制代码
@GetMapping("/list")
public List<Goods> list(@RequestHeader("token") String token ){
    System.out.println(token);
    System.out.println("我被调用");
  return  goodsService.list();
}

全局过滤器

default-filters为全局的不需要一个个配置

yml 复制代码
gateway:
  routes:
    - id: java-user #路由ID 一般为服务名称
      uri: lb://java-user #转发的路径 lb为负载均衡 java-user为服务接口
      predicates: #路由条件
        - Path=/user/** #请求接口路径
        # - Path=/user/**,/path/**    多个控制器这样写
    - id: java-goods
      uri: lb://java-goods
      predicates:
        - Path=/goods/**
  default-filters:
    - AddRequestHeader=token,123456
相关推荐
二哈赛车手7 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
栗子~~8 小时前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
YDS8298 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— RAG知识库的搭建和接口实现
java·ai·springboot·agent·rag·deepseek
candyTong9 小时前
Claude Code 的 Edit 工具是怎么工作的
javascript·后端·架构
未若君雅裁9 小时前
MyBatis 一级缓存、二级缓存与清理机制
java·缓存·mybatis
AI人工智能+电脑小能手10 小时前
【大白话说Java面试题 第65题】【JVM篇】第25题:谈谈对 OOM 的认识
java·开发语言·jvm
GetcharZp10 小时前
GitHub 2.4 万 Star!D2 正在重新定义程序员画图方式
后端
阿维的博客日记10 小时前
Nacos 为什么能让配置动态生效?(涉及 @RefreshScope 注解)
java·spring
雨辰AI10 小时前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
辰海Coding12 小时前
MiniSpring框架学习-完成的 IoC 容器
java·spring boot·学习·架构