0

0

Spring Cloud Gateway 实现带路径保留的跨域重定向(302)

花韻仙語

花韻仙語

发布时间:2026-01-22 11:18:02

|

295人浏览过

|

来源于php中文网

原创

Spring Cloud Gateway 实现带路径保留的跨域重定向(302)

本文详解如何在 spring cloud gateway 中正确配置重定向,使请求路径(如 /site/rest/services/testservice/1)完整保留在目标 url 中,避免仅跳转到根路径。核心在于动态构造目标 uri,而非硬编码重定向地址。

在 Spring Cloud Gateway 中,直接使用 f.redirect(302, "https://internal-api.com") 会导致路径丢失——因为该过滤器仅将客户端重定向至指定 URL 的根路径(即 https://internal-api.com/),而不会自动拼接原始请求路径(如 /site/rest/services/testservice/1)。这是 RedirectToGatewayFilterFactory 的设计行为:它只接受一个固定目标 URI,不支持路径模板或变量注入。

✅ 正确解法是手动修改请求 URI,再配合 redirect 过滤器(或更推荐:直接返回 302 响应),确保重定向 Location 头包含完整的路径。以下是经过验证的生产级实现:

智川X-Agent
智川X-Agent

中科闻歌推出的一站式AI智能体开发平台

下载
@Bean
public RouteLocator routes(RouteLocatorBuilder builder) {
    String auth = username + ":" + password;
    String encodedAuth = Base64.getEncoder().encodeToString(auth.getBytes());

    return builder.routes()
        .route("geoApi", r -> r
            .path("/site/rest/services/**")
            .filters(f -> f
                .setHeader(HttpHeaders.AUTHORIZATION, "Basic " + encodedAuth)
                // ✅ 关键:动态构建目标 URI,保留原始路径与查询参数
                .modifyRequestBody(Void.class, Void.class, (exchange, body) -> {
                    // 注意:此处仅用于触发链式调用;实际重定向由下方 redirect 完成
                    return Mono.just(body);
                })
                // ✅ 核心:使用 changeRequestUri 动态生成含路径的目标地址
                .changeRequestUri(exchange -> {
                    URI originalUri = exchange.getRequest().getURI();
                    UriComponentsBuilder builder = UriComponentsBuilder
                        .fromUri(originalUri)
                        .scheme("https")
                        .host("internal-api.com")
                        .port(-1); // -1 表示移除端口(若原 URI 无端口)
                    return Optional.of(builder.build(true).toUri());
                })
                // ✅ 触发 302 重定向(此时 request URI 已更新,Location 即为其值)
                .redirect(302, exchange -> exchange.getRequest().getURI())
            )
            .uri("https://dummy.com") // ⚠️ 此 uri 不参与重定向逻辑,仅作占位(必须非空)
        )
        .build();
}

⚠️ 重要说明与注意事项:

  • changeRequestUri 是 Gateway 3.1+ 推荐的方式(替代已废弃的 rewritePath + redirect 组合),它在路由匹配后、过滤器执行前修改请求上下文中的 URI,后续 redirect 过滤器会自动读取该 URI 作为重定向目标。
  • .uri("https://dummy.com") 是必需的占位符——Spring Cloud Gateway 要求每个路由必须声明 uri(),但它不会被实际调用;真正的目标由 changeRequestUri 和 redirect 共同决定。
  • 若需添加认证头(如 Basic Auth),请确保 setHeader 在 changeRequestUri 之前执行,否则可能因请求上下文未就绪导致异常。
  • 不建议使用字符串拼接(如 "https://internal-api.com" + originalUri.getPath()),因为它会丢失查询参数(?key=value)和编码信息;UriComponentsBuilder 可安全保留全部 URI 组成部分。

? 进阶提示:
若需更灵活控制(如条件重定向、多环境 Host 切换),可将 internal-api.com 提取为配置项(如 @Value("${api.internal.host}")),并结合 RouteLocatorBuilder 的 id() 和 order() 实现优先级路由。

综上,通过 changeRequestUri 动态重建目标 URI,是 Spring Cloud Gateway 中实现路径感知重定向最清晰、可靠且符合官方最佳实践的方式。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

156

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

88

2026.01.26

504 gateway timeout怎么解决
504 gateway timeout怎么解决

504 gateway timeout的解决办法:1、检查服务器负载;2、优化查询和代码;3、增加超时限制;4、检查代理服务器;5、检查网络连接;6、使用负载均衡;7、监控和日志;8、故障排除;9、增加缓存;10、分析请求。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

607

2023.11.27

default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

236

2023.12.07

Java 微服务与 Spring Cloud 实战
Java 微服务与 Spring Cloud 实战

本专题讲解 Java 微服务架构的开发与实践,重点使用 Spring Cloud 实现服务注册与发现、负载均衡、熔断与限流、分布式配置管理、API Gateway 和消息队列。通过实际项目案例,帮助开发者理解 如何将传统单体应用拆分为高可用、可扩展的微服务架构,并有效管理和调度分布式系统中的各个组件。

51

2026.02.05

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1566

2023.10.24

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Rust 教程
Rust 教程

共28课时 | 6.8万人学习

Git 教程
Git 教程

共21课时 | 4.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号