原文鏈接: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"));
-
-
}