Java 过滤器Url通配符处理
原文链接:https://blog.csdn.net/washingtin/article/details/102976660
今天遇到项目中,加过滤器调试麻烦的问题。加上了一个过滤器来处理每次登录的问题。
代码如下:
-
/**
-
* 将通配符表达式转化为正则表达式
-
*
-
* @param path
-
* @return
-
*/
-
private String getRegPath(String path) {
-
char[] chars = path.toCharArray();
-
int len = chars.length;
-
StringBuilder sb = new StringBuilder();
-
boolean preX = false;
-
for (int i = 0; i < len; i++) {
-
if (chars[i] == '*') {//遇到*字符
-
if (preX) {//如果是第二次遇到*,则将**替换成.*
-
sb.append(".*");
-
preX = false;
-
} else if (i + 1 == len) {//如果是遇到单星,且单星是最后一个字符,则直接将*转成[^/]*
-
sb.append("[^/]*");
-
} else {//否则单星后面还有字符,则不做任何动作,下一把再做动作
-
preX = true;
-
continue;
-
}
-
} else {//遇到非*字符
-
if (preX) {//如果上一把是*,则先把上一把的*对应的[^/]*添进来
-
sb.append("[^/]*");
-
preX = false;
-
}
-
if (chars[i] == '?') {//接着判断当前字符是不是?,是的话替换成.
-
sb.append('.');
-
} else {//不是?的话,则就是普通字符,直接添进来
-
sb.append(chars[i]);
-
}
-
}
-
}
-
return sb.toString();
-
}
-
-
/**
-
* 通配符模式
-
*
-
* @param excludePath - 不过滤地址
-
* @param reqUrl - 请求地址
-
* @return
-
*/
-
private boolean filterUrls(String excludePath, String reqUrl) {
-
String regPath = getRegPath(excludePath);
-
return Pattern.compile(regPath).matcher(reqUrl).matches();
-
}
-
-
/**
-
* 检验是否在非过滤地址
-
*
-
* @param excludeUrls
-
* @param reqUrl
-
* @return
-
*/
-
private boolean checkWhiteList(String[] excludeUrls, String reqUrl) {
-
for (String url : excludeUrls) {
-
if (filterUrls(url, reqUrl)) {
-
return true;
-
}
-
}
-
return false;
-
}
-
测试代码:
-
public static void main(String[] args) {
-
String[] excludeUrl = new String[]{"/abf/*","/abd/**","*.login","*.html","*.jsp","/abg/login"};
-
-
System.out.println(checkWhiteList(excludeUrl, "/abf/test/login"));
-
-
}