springMVC中/*与/**匹配的区别

在 Spring MVC 中,这两个模式只差了一颗星,但匹配的"深度"完全不同。

一句话:

  • /user/* 只能匹配一级,即 /user/abc/user/123 都 OK,但 /user/abc/profile 就不行。
  • /user/** 可以匹配无限多级,即 /user 及其下面任意层级的路径都 OK,例如 /user/user/abc/user/abc/profile/user/a/b/c/d 等。

下面把规则展开说清,并给出代码示例,方便你一眼看出区别。


  1. Ant 风格路径通配符规则(Spring 用到)
  • ? 匹配任意单个字符
  • * 匹配任意一段 字符(不能跨 /
  • ** 匹配任意多段 字符(可以跨 /,必须是整个路径段)
  1. 对应关系
    模式 能否匹配 举例

/user/* 只能匹配 /user/ 下一级 /user/123 ✔

/user/123/info ✘

/user/** 可匹配 /user 及其下任意层级 /user ✔

/user/123 ✔

/user/123/info ✔

/user/a/b/c/d ✔

  1. 代码示例
java 复制代码
@Configuration
public class WebConfig implements WebMvcConfigurer {
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        // 只拦截 /user/ 下一级
        registry.addInterceptor(new UserInterceptor())
                .addPathPatterns("/user/*");

        // 拦截 /user 及其所有子路径
        // registry.addInterceptor(new UserInterceptor())
        //         .addPathPatterns("/user/**");
    }
}
  1. 容易踩的坑
  • /user/* 不会匹配到 /user 本身(因为 * 至少要有一段字符)。
    如果你想把 /user 也一起拦截,需要再加一条 /user 或者改用 /user/**
  • 如果用了 /** 又只想排除某些子路径,记得再配合 excludePathPatterns("...") 使用。

结论

记住一句话:

"单星只走一层,双星层层通吃"。

根据业务需要选择即可。

相关推荐
怒放吧德德5 小时前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty
雨中飘荡的记忆7 小时前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
心之语歌9 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
华仔啊10 小时前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang10 小时前
用六边形架构与整洁架构对比是伪命题?
java·架构
用户83071968408210 小时前
spring ai alibaba + nacos +mcp 实现mcp服务负载均衡调用实战
spring boot·spring·mcp
Ray Liang12 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
Java水解12 小时前
Java 中间件:Dubbo 服务降级(Mock 机制)
java·后端
SimonKing16 小时前
OpenCode AI辅助编程,不一样的编程思路,不写一行代码
java·后端·程序员
FastBean16 小时前
Jackson View Extension Spring Boot Starter
java·后端