Gateway整合knife4报错404 (Not Found)

在 Spring Cloud Gateway 中整合 Knife4j 后,访问 http://localhost:8000/doc.html 报错,提示 /v3/api-docs/swagger-config 404

这是 Spring Cloud Gateway + Knife4j 的典型配置问题。根本原因在于:

Gateway 本身没有接口文档(Swagger/OpenAPI) ,它只是一个路由网关。真正的文档在各个微服务中,Gateway 需要将 /doc.html/v3/api-docs/** 等请求 正确转发到下游服务 ,或者 聚合多个服务的文档

而你只加了 knife4j-gateway-spring-boot-starter,但 没有配置文档聚合或路由规则 ,导致前端请求 /v3/api-docs/swagger-config 时,Gateway 找不到对应处理路径,返回 404。

在 Gateway 中配置聚合
xml 复制代码
<dependency>
    <groupId>com.github.xiaoymin</groupId>
    <artifactId>knife4j-gateway-spring-boot-starter</artifactId>
    <version>4.5.0</version>
</dependency>
application.yml 中配置聚合规则
yaml 复制代码
knife4j:
  gateway:
    enabled: true
    strategy: discover  # 自动发现(基于服务注册中心)
    # 或者手动配置 routes(见下方)
    routes:
      - name: 用户服务
        url: /user-service/v3/api-docs
        service-name: user-service   # 注册中心中的服务名
      - name: 内容服务
        url: /content-service/v3/api-docs
        service-name: content-service

注意:url 路径必须与你在 Gateway 中配置的路由前缀一致!

确保 Gateway 有对应的路由规则

(转发 /user-service/** 到 user-service):

yaml 复制代码
spring:
  cloud:
    gateway:
      routes:
        - id: user-service
          uri: lb://user-service
          predicates:
            - Path=/user-service/**

这样,当你访问 http://localhost:8000/doc.html 时:

  • Knife4j 前端会请求 /v3/api-docs/swagger-config → 由 knife4j-gateway-starter 拦截并返回聚合配置
  • 然后按服务加载各自的 /v3/api-docs
相关推荐
三口吃掉你2 小时前
微服务之网关(Spring Cloud Gateway)
java·网关·微服务·gateway
Kent_J_Truman2 小时前
JDK Maven Tomcat Spring在VSCode中的部分配置细节(自用)
java·tomcat·maven
邂逅星河浪漫2 小时前
【Java】异常详解+实例演示+知识总结
java·异常·exception
她说人狗殊途2 小时前
面试题001
java
Han.miracle2 小时前
Java的多线程——多线程(3)线程安全
java·开发语言·jvm·学习·安全·线程·多线程
大象席地抽烟2 小时前
spring中使用rabbitmq(spring-boot-starter-amqp)
java
运维_攻城狮2 小时前
Nexus 3.x 私服搭建与运维完全指南(Maven 实战)
java·运维·maven
R.lin2 小时前
mmap内存映射文件
java·后端
chxii2 小时前
Maven 详解(中)
java·maven