Spring MVC 重定向(Redirect)详解

news2025/4/14 12:00:10

在这里插入图片描述

Spring MVC 重定向(Redirect)详解


1. 核心概念与作用

重定向(Redirect) 是 Spring MVC 中一种客户端重定向机制,通过 HTTP 302 状态码(默认)将用户浏览器重定向到指定 URL。

  • 主要用途
    • 防止表单重复提交(提交后跳转到新页面)。
    • 实现页面跳转(如登录成功后跳转到主页)。
    • URL 重写或简化(如将 /old-path 重定向到 /new-path)。

2. 基本使用方式

2.1 通过返回值直接重定向

在控制器方法中直接返回 redirect:URL 格式的字符串:

@GetMapping("/login")
public String loginSuccess() {
    // 登录成功后重定向到主页
    return "redirect:/home"; 
}
2.2 指定重定向 URL 路径
  • 绝对路径redirect:/home
  • 相对路径redirect:../another-page(不推荐,易出错)
  • 外部 URLredirect:https://example.com(需谨慎使用)。

3. 传递参数到重定向目标

3.1 在 URL 中追加查询参数
@GetMapping("/search")
public String search(@RequestParam String query) {
    return "redirect:/results?query=" + query; // 原始方式
}
3.2 使用占位符语法(推荐)

Spring 提供模板化的参数注入:

@GetMapping("/search")
public String search(@RequestParam String query) {
    // 使用占位符 {query} 自动替换
    return "redirect:/results?query={query}".replace("{query}", query);
}
// 或更简洁的写法:
return "redirect:/results?query=" + URLEncoder.encode(query, StandardCharsets.UTF_8);

4. 通过 RedirectAttributes 传递数据

RedirectAttributes 是 Spring 提供的专门用于重定向时传递数据的接口,数据会通过 Flash Scope 存储(在重定向请求中有效)。

4.1 基本用法
@PostMapping("/submit")
public String submitForm(@ModelAttribute FormData data, RedirectAttributes attributes) {
    // 存储数据到 Flash Scope
    attributes.addAttribute("message", "提交成功");
    attributes.addFlashAttribute("user", data.getUser());
    return "redirect:/confirmation";
}
4.2 在目标页面获取数据
@GetMapping("/confirmation")
public String showConfirmation(@ModelAttribute("user") User user,
                              @RequestParam("message") String message) {
    // 处理数据
    return "confirmation";
}

5. 使用 RedirectView 对象

通过返回 RedirectView 对象实现重定向,提供更多控制选项:

@GetMapping("/custom-redirect")
public RedirectView customRedirect() {
    RedirectView redirectView = new RedirectView("/home", true); // 第二个参数:是否重写 URL
    redirectView.setUrl("/home?param=value");
    return redirectView;
}

6. 与转发(Forward)的区别
对比项重定向(Redirect)转发(Forward)
请求次数生成新的 HTTP 请求(客户端发起)单次请求,服务器内部跳转
URL 变化浏览器地址栏显示新 URL地址栏 URL 保持不变
数据传递需通过 URL 参数或 Flash Scope可直接传递模型数据(Model
适用场景防重复提交、跨控制器跳转内部页面跳转(如模块间协作)

7. 完整代码示例

7.1 基础重定向
@Controller
public class RedirectController {

    @GetMapping("/login")
    public String login() {
        // 直接重定向到主页
        return "redirect:/home";
    }

    @GetMapping("/home")
    public String home() {
        return "home"; // 返回视图名称
    }
}
7.2 带参数的重定向
@GetMapping("/search")
public String search(@RequestParam String query) {
    // 将查询参数传递到 results 页面
    return "redirect:/results?query=" + URLEncoder.encode(query, StandardCharsets.UTF_8);
}

@GetMapping("/results")
public String results(@RequestParam String query, Model model) {
    model.addAttribute("query", query);
    return "results";
}
7.3 使用 RedirectAttributes
@PostMapping("/submit")
public String submitForm(@ModelAttribute FormData data, RedirectAttributes attributes) {
    attributes.addFlashAttribute("successMessage", "提交成功");
    return "redirect:/thank-you";
}

@GetMapping("/thank-you")
public String thankYou(@ModelAttribute("successMessage") String message, Model model) {
    model.addAttribute("message", message);
    return "thank-you";
}

8. 常见问题与解决方案

Q1:重定向后参数丢失?
  • 原因:未正确编码特殊字符(如空格、中文)。
  • 解决:使用 URLEncoder.encode() 编码参数:
    String encodedQuery = URLEncoder.encode(query, StandardCharsets.UTF_8);
    return "redirect:/results?query=" + encodedQuery;
    
Q2:如何修改重定向的 HTTP 状态码(如 301)?
  • 默认:Spring 使用 302 临时重定向。
  • 自定义状态码:需结合 ResponseEntity
    @GetMapping("/permanent-redirect")
    public ResponseEntity<?> permanentRedirect() {
        return ResponseEntity.status(301).location(URI.create("/new-url")).build();
    }
    
Q3:RedirectAttributes 的数据在目标页面不可见?
  • 原因:未使用 addFlashAttribute(),而是直接 addAttribute()
  • 修正
    attributes.addFlashAttribute("user", user); // 使用 addFlashAttribute()
    

9. 总结表格:重定向方法对比
方法类型实现方式参数传递能力适用场景
返回字符串return "redirect:/url"简单参数基础重定向
RedirectView返回 RedirectView 对象高度灵活需自定义重定向逻辑
RedirectAttributes通过 addFlashAttribute()复杂对象需传递模型数据到重定向页面

总结

Spring MVC 的重定向机制通过 redirect: 前缀和 RedirectAttributes 等工具,提供了灵活的跳转能力。核心是理解客户端重定向与服务器转发的区别,以及如何安全地传递数据。实际开发中,推荐使用 RedirectAttributes 处理复杂数据,避免手动拼接 URL 参数可能带来的安全风险(如 XSS 攻击)。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2331479.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

window上 docker使用ros2开发并usbip共享usb设备

曾经参考 https://blog.csdn.net/laoxue123456/article/details/138339029 来共享windows上的usb 发现没有办法成功总是出现 tcp 错误。telnet测试能够正常连接 很是奇怪&#xff0c;window上换成低版本的usbipd仍然是同样的错误&#xff0c;没有办法的情况下参考了docker官方文…

基于MATLAB/simulink的信号调制仿真--AM调制

实验内容&#xff1a; 假设y(t)(20.5*2cos&#xff08;2*pi*1000*t&#xff09;)*5cos&#xff08;2*pi*2*1e4*t&#xff09;调幅系统&#xff0c;请将一个频率为1000HZ的余弦波信号&#xff0c;通过进行AM调制&#xff0c;载波信号频率为20kHZ的余弦波&#xff0c;调制度ma0.…

Vue3+Ts封装ToolTip组件(2.0版本)

本组件支持hover和click两种触发方式&#xff0c;需要更多的触发方式&#xff0c;可自行去扩展&#xff01;&#xff01;&#xff01; 1.传递三个参数&#xff1a; content&#xff1a;要展示的文本 position&#xff1a;文本出现的位置&#xff08;"top" | "t…

Latex语法入门之数学公式

Latex是一种高质量的排版系统&#xff0c;尤其擅长于数学公式的排版。本文我将带大家深入了解Latex在数学公式排版中的应用。从基础的数学符号到复杂的公式布局&#xff0c;我们都会一一讲解&#xff0c;通过本文的学习&#xff0c;你将能够轻松编写出清晰、美观的数学公式&…

shell脚本 - Linux定时温度监控-软硬件检测 - 服务器温度监控 - 写入日志

效果图 脚本 vi auto.sh (chmod x ./auto.sh) #!/bin/bash # 按照日期创建一个文件或目录 https://blog.csdn.net/shoajun_5243/article/details/83539069 datetimedate %Y%m%d-%H%M%S |cut -b1-20 dirpath/systemMonitor/$datetime file1$dirpath/sensors.log file2$dirpa…

Linux驱动开发进阶(六)- 多线程与并发

文章目录 1、前言2、进程与线程3、内核线程4、底半步机制4.1、软中断4.2、tasklet4.3、工作队列4.3.1、普通工作项4.3.2、延时工作项4.3.3、工作队列 5、中断线程化6、进程6.1、内核进程6.2、用户空间进程 7、锁机制7.1、原子操作7.2、自旋锁7.3、信号量7.4、互斥锁7.5、comple…

买不起了,iPhone 或涨价 40% ?

周知的原因&#xff0c;新关税对 iPhone 的打击&#xff0c;可以说非常严重。 根据 Rosenblatt Securities分析师的预测&#xff0c;若苹果完全把成本转移给消费者。 iPhone 16 标配版的价格&#xff0c;可能上涨43%。 iPhone 16 标配的价格是799美元&#xff0c;上涨43%&am…

Axure 列表滚动:表头非常多(横向滚动方向)、分页(纵向滚动) | 基于动态面板的滚动方向和取消调整大小以适合内容两个属性进行实现

文章目录 引言I 列表滚动的操作说明see also共享原型引言 Axure RP9教程 【数据传输】(页面值传递)| 作用域 :全局变量、局部变量 https://blog.csdn.net/z929118967/article/details/147019839?spm=1001.2014.3001.5501 基于动态面板的滚动方向和取消调整大小以适合内容两…

RBAC 权限控制:深入到按钮级别的实现

RBAC 权限控制&#xff1a;深入到按钮级别的实现 一、前端核心思路 1. 大致实现思路 后端都过SELECT连表查询把当前登录的用户对应所有的权限返回过来&#xff0c;前端把用户对应所有的权限 存起来to(vuex/pinia) 中 &#xff0c;接着前端工程师需要知道每个按钮对应的权限代…

【区间贪心】合并区间 / 无重叠区间 / 用最少数量的箭引爆气球 / 俄罗斯套娃信封问题

⭐️个人主页&#xff1a;小羊 ⭐️所属专栏&#xff1a;贪心算法 很荣幸您能阅读我的文章&#xff0c;诚请评论指点&#xff0c;欢迎欢迎 ~ 目录 合并区间无重叠区间用最少数量的箭引爆气球俄罗斯套娃信封问题 合并区间 合并区间 class Solution { public:vector<vecto…

es --- 集群数据迁移

目录 1、需求2、工具elasticdump2.1 mac安装问题解决 2.2 elasticdump文档 3、迁移 1、需求 迁移部分新集群没有的索引和数据 2、工具elasticdump Elasticdump 的工作原理是将输入发送到输出 。两者都可以是 elasticsearch URL 或 File 2.1 mac安装 前置&#xff1a;已经安装…

【有啥问啥】深入浅出讲解 Teacher Forcing 技术

深入浅出讲解 Teacher Forcing 技术 在序列生成任务&#xff08;例如机器翻译、文本摘要、图像字幕生成等&#xff09;中&#xff0c;循环神经网络&#xff08;RNN&#xff09;以及基于 Transformer 的模型通常采用自回归&#xff08;autoregressive&#xff09;的方式生成输出…

zk基础—zk实现分布式功能

1.zk实现数据发布订阅 (1)发布订阅系统一般有推模式和拉模式 推模式&#xff1a;服务端主动将更新的数据发送给所有订阅的客户端。 拉模式&#xff1a;客户端主动发起请求来获取最新数据(定时轮询拉取)。 (2)zk采用了推拉相结合来实现发布订阅 首先客户端需要向服务端注册自己关…

ubuntu wifi配置(命令行版本)

1、查询当前设备环境的wifi列表 nmcli dev wifi list2、连接wifi nmcli dev wifi connect "MiFi-SSID" password "Password" #其中MiFi-SSID是wifi的密码&#xff0c;Password是wifi的密码3、查看连接情况 nmcli dev status

Docker与Kubernetes在ZKmall开源商城容器化部署中的应用

ZKmall开源商城作为高并发电商系统&#xff0c;其容器化部署基于DockerKubernetes技术栈&#xff0c;实现了从开发到生产环境的全流程标准化与自动化。以下是核心应用场景与技术实现&#xff1a; 一、容器化基础&#xff1a;Docker镜像与微服务隔离 ​服务镜像标准化 ​分层构建…

华为AI-agent新作:使用自然语言生成工作流

论文标题 WorkTeam: Constructing Workflows from Natural Language with Multi-Agents 论文地址 https://arxiv.org/pdf/2503.22473 作者背景 华为&#xff0c;北京大学 动机 当下AI-agent产品百花齐放&#xff0c;尽管有ReAct、MCP等框架帮助大模型调用工具&#xff0…

MYSQL数据库语法补充

一&#xff0c;DQL基础查询 DQL&#xff08;Data Query Language&#xff09;数据查询语言&#xff0c;可以单表查询&#xff0c;也可以多表查询 语法&#xff1a; select 查询结果 from 表名 where 条件&#xff1b; 特点&#xff1a; 查询结果可以是&#xff1a;表中的字段…

在Windows搭建gRPC C++开发环境

一、环境构建 1. CMake Download CMake 2. Git Git for Windows 3. gRPC源码 git clone -b v1.48.0 https://github.com/grpc/grpc 进入源码目录 cd grpc 下载依赖库 git submodule update --init 二、使用CMake生成工程文件 三、使用vs2019编译grpc库文件 四、使用…

[Python] 企业内部应用接入钉钉登录,端内免登录+浏览器授权登录

[Python] 为企业网站应用接入钉钉鉴权&#xff0c;实现钉钉客户端内自动免登授权&#xff0c;浏览器中手动钉钉授权登录两种逻辑。 操作步骤 企业内部获得 开发者权限&#xff0c;没有的话先申请。 访问 钉钉开放平台-应用开发 创建一个 企业内部应用-钉钉应用。 打开应用…

用AbortController取消事件绑定

视频教程 React - &#x1f914; Abort Controller 到底是什么神仙玩意&#xff1f;看完这个视频你就明白了&#xff01;&#x1f4a1;_哔哩哔哩_bilibili AbortController的好处之一是事件绑定的函数已无需具名函数,匿名函数也可以被取消事件绑定了 //该代码2秒后点击失效…