spring基于url路径匹配用法经验介绍

          在web应用中,需要对请求url路径进行一些判断匹配,完成一定的功能,如进行访问权限的判断,acegi就采用了路径匹配来判断请求url路径是否为合法,但是没有将api抽取出来,用起来还是依赖性太强,不好做轻量级的扩展。spring提供了工具类AntPathMatcher实现了判断路径匹配,非常简单好用,属轻量级的组件,下面具体谈一下。

          先贴一段代码来快速了解一下它的用法(可以看一下代码注释,比较详细),如下: 

package test.web;

import org.springframework.util.AntPathMatcher;
import org.springframework.util.PathMatcher;

import junit.framework.TestCase;                                                                                          

/**
 * 路径匹配
 * @author yandk
 * @date Feb 15, 2012
 */
public class TestAntPathMatcher extends TestCase{
 public void testMatch(){
  PathMatcher  matcher = new AntPathMatcher();
//  完全路径url方式路径匹配                                                                                            
//  String requestPath="请求路径                                                                                                                                                                                            
//  String patternPath="**/login.jsp";//路径匹配模式
  
//  不完整路径uri方式路径匹配
//  String requestPath="/app/pub/login.do";//请求路径
//  String patternPath="/**/login.do";//路径匹配模式
//  模糊路径方式匹配
//  String requestPath="/app/pub/login.do";//请求路径
//  String patternPath="/**/*.do";//路径匹配模式
//  包含模糊单字符路径匹配
  String requestPath="/app/pub/login.do";//请求路径
  String patternPath="/**/lo?in.do";//路径匹配模式

  boolean result =matcher.match(patternPath, requestPath);
  assertTrue(result);
 }

注:以上代码取消注释的片段,都能通过测试,使用时可根据具体情况调整即可。

总结如下:

ANT方式的通配符有三种:

    ?(匹配任何单字符),*(匹配0或者任意数量的字符),**(匹配0或者更多的目录)

url路径匹配规则:

URL路径说明
/app/*.x匹配(Matches)所有在app路径下的.x文件
/app/p?ttern匹配(Matches) /app/pattern 和 /app/pXttern,但是不包括/app/pttern
/**/example匹配(Matches) /app/example, /app/foo/example, 和 /example
/app/**/dir/file.匹配(Matches) /app/dir/file.jsp, /app/foo/dir/file.html,/app/foo/bar/dir/file.pdf, 和 /app/dir/file.java
/**/*.jsp匹配(Matches)任何的.jsp 文件

最长匹配原则(has more characters)
说明,URL请求/app/dir/file.jsp,现在存在两个路径匹配模式/**/*.jsp和/app/dir/*.jsp,那么会根据模式/app/dir/*.jsp来匹配

  

 

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

云焰

你的鼓励是我创作的最大动力。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值