0

0

如何在 Spring MVC 中获取不包含路径变量的请求 URI

碧海醫心

碧海醫心

发布时间:2026-02-11 11:53:48

|

631人浏览过

|

来源于php中文网

原创

如何在 Spring MVC 中获取不包含路径变量的请求 URI

本文介绍在 spring mvc 控制器中,如何从 `httpservletrequest` 中提取原始请求路径(如 `/getuser/`),自动剥离 `@pathvariable` 动态段,避免手动硬编码或字符串解析错误。

在 Spring MVC 开发中,常需基于当前请求路径进行日志记录、权限校验、链路追踪或动态路由匹配。但直接调用 request.getRequestURI() 或 request.getServletPath() 会返回包含实际路径变量值的完整路径(例如 /getUser/tommy),而我们真正需要的是模板化路径——即控制器映射定义中的静态部分(如 /getUser/{username} 对应的 /getUser/)。

Spring MVC 本身未提供开箱即用的 API 直接返回“无变量路径”,但可通过组合 HttpServletRequest 的标准方法 + 路径变量信息,安全、可靠地还原出目标路径。

核心思路:利用 getServletPath() 与 @PathVariable 协同推导

HttpServletRequest.getServletPath() 返回的是当前请求匹配到的 Servlet 映射路径(不含上下文路径和查询参数),它已由 Spring 解析并去除了上下文前缀,是计算的基础。关键在于:路径变量值必然位于 getServletPath() 的末尾,且其位置可被精确识别

Interior AI
Interior AI

AI室内设计,上传室内照片自动帮你生成多种风格的室内设计图

下载

以下是一个健壮、可复用的实现方式:

@GetMapping("/getUser/{username}")
public ResponseEntity getUser(
        @PathVariable String username,
        HttpServletRequest request) {

    String servletPath = request.getServletPath(); // e.g. "/getUser/tommy"

    // 安全截取:从末尾移除变量值及前导斜杠
    int lastSlashIndex = servletPath.lastIndexOf('/');
    if (lastSlashIndex > 0 && servletPath.length() > lastSlashIndex + username.length()) {
        String pathWithoutVar = servletPath.substring(0, lastSlashIndex + 1); // 保留末尾 '/'
        // 或使用 substring(0, lastSlashIndex) 获取不带尾部 '/' 的版本(如 "/getUser")
        System.out.println("Template path: " + pathWithoutVar); // 输出:"/getUser/"
    }

    // ... 业务逻辑
    return ResponseEntity.ok(new UserDTO());
}
✅ 优势说明: 不依赖正则或硬编码路径模板,完全基于运行时真实请求信息; 避免因多级嵌套变量(如 /api/v1/users/{id}/posts/{postId})导致的解析歧义; lastIndexOf('/') 确保只移除最后一个路径段(即最外层 @PathVariable),符合 RESTful 设计惯例。

注意事项与最佳实践

  • 仅适用于单个末尾 @PathVariable 场景:上述方法默认假设动态段位于路径最末端。若存在多个变量(如 /{year}/{month}/{day}),建议改用 HandlerMapping.BEST_MATCHING_PATTERN_ATTRIBUTE(需启用 useRegisteredSuffixPatternMatch):
    String pattern = (String) request.getAttribute(HandlerMapping.BEST_MATCHING_PATTERN_ATTRIBUTE);
    // pattern = "/getUser/{username}" → 可直接用于审计或路由匹配
  • 空值与边界检查不可省略:username 可能为空字符串或含斜杠(虽不推荐),务必校验 lastSlashIndex 和长度,防止 StringIndexOutOfBoundsException。
  • 上下文路径隔离:getServletPath() 已排除 getContextPath(),因此无需额外处理上下文(如 /myapp),结果天然可移植。
  • 替代方案对比
    • ❌ request.getRequestURI() 包含完整 URI(含上下文),需额外裁剪;
    • ❌ 正则替换 /{[^}]+} 易受路径中特殊字符干扰,且无法区分模板与字面量;
    • ✅ getServletPath() + lastIndexOf('/') 是轻量、标准、零依赖的最优解。

综上,在绝大多数标准 REST 接口场景下,通过 request.getServletPath() 结合 @PathVariable 值进行末段截断,是最简洁、高效且符合 Servlet 规范的实现方式。它既规避了框架内部实现细节耦合,又保持了代码的可读性与可维护性。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

120

2025.08.06

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

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

77

2026.01.26

PHP API接口开发与RESTful实践
PHP API接口开发与RESTful实践

本专题聚焦 PHP在API接口开发中的应用,系统讲解 RESTful 架构设计原则、路由处理、请求参数解析、JSON数据返回、身份验证(Token/JWT)、跨域处理以及接口调试与异常处理。通过实战案例(如用户管理系统、商品信息接口服务),帮助开发者掌握 PHP构建高效、可维护的RESTful API服务能力。

171

2025.11.26

servlet生命周期
servlet生命周期

Servlet生命周期是指Servlet从创建到销毁的整个过程。本专题为大家提供servlet生命周期的各类文章,大家可以免费体验。

382

2023.08.08

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

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

488

2023.08.03

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

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

214

2023.09.04

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

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

1548

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

640

2023.11.24

2026春节习俗大全
2026春节习俗大全

本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

68

2026.02.11

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP+MySQL基础入门课程
PHP+MySQL基础入门课程

共113课时 | 8.1万人学习

PHP MySQL基础编程课
PHP MySQL基础编程课

共111课时 | 9.4万人学习

PHP编程(基础知识点汇总)
PHP编程(基础知识点汇总)

共85课时 | 6.3万人学习

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

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