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
相关推荐
麦麦鸡腿堡18 小时前
JavaWeb_请求参数,设置响应数据,分层解耦
java·开发语言·前端
没有bug.的程序员19 小时前
Serverless 弹性扩容引发的全线熔断:Spring Boot 启动耗时从 1s 压缩至 0.3s 的物理级绞杀
java·spring boot·kubernetes·serverless·扩容·线上
bearpping19 小时前
java进阶知识点
java·开发语言
独自破碎E19 小时前
【面试真题拆解】你知道ThreadLocal是什么吗
java·jvm·面试
kkkkatoq19 小时前
JAVA中的IO操作
java·开发语言
深蓝轨迹20 小时前
@Autowired与@Resource:Spring依赖注入注解核心差异剖析
java·python·spring·注解
不想看见40420 小时前
C++八股文【详细总结】
java·开发语言·c++
huaweichenai20 小时前
java的数据类型介绍
java·开发语言
weisian15120 小时前
Java并发编程--17-阻塞队列BlockingQueue:生产者-消费者模式的最佳实践
java·阻塞队列·blockqueue
奔跑的呱呱牛20 小时前
GeoJSON 在大数据场景下为什么不够用?替代方案分析
java·大数据·servlet·gis·geojson