Ответ 1
Вы можете использовать
org.apache.commons.lang3.StringUtils.containsIgnoreCase(CharSequence str,
CharSequence searchStr);
Проверяет, содержит ли CharSequence поиск CharSequence независимо от случай, обращение null. Нечувствительность к регистру определяется как String.equalsIgnoreCase(String).
Нуль CharSequence вернет false.
Это будет лучше, чем регулярное выражение, поскольку регулярное выражение всегда дорого с точки зрения производительности.
Для официального документа обратитесь к: StringUtils.containsIgnoreCase
Обновление:
Если вы среди тех, кто
- не хотят использовать библиотеку сообщества Apache
- не хотят идти с дорогими решениями
regex/Pattern
, - не нужно создавать дополнительный объект строки с помощью
toLowerCase
,
вы можете реализовать свой собственный containsIgnoreCase
с помощью java.lang.String.regionMatches
public boolean regionMatches(boolean ignoreCase,
int toffset,
String other,
int ooffset,
int len)
ignoreCase
: if true, игнорирует случай при сравнении символов.
public static boolean containsIgnoreCase(String str, String searchStr) {
if(str == null || searchStr == null) return false;
final int length = searchStr.length();
if (length == 0)
return true;
for (int i = str.length() - length; i >= 0; i--) {
if (str.regionMatches(true, i, searchStr, 0, length))
return true;
}
return false;
}