StringUtils.java 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569
  1. package com.ozs.common.utils;
  2. import java.util.ArrayList;
  3. import java.util.Collection;
  4. import java.util.HashSet;
  5. import java.util.List;
  6. import java.util.Map;
  7. import java.util.Set;
  8. import org.springframework.util.AntPathMatcher;
  9. import com.ozs.common.constant.Constants;
  10. import com.ozs.common.core.text.StrFormatter;
  11. /**
  12. * 字符串工具类
  13. *
  14. * @author hx
  15. */
  16. public class StringUtils extends org.apache.commons.lang3.StringUtils {
  17. //为null,为"",为 " " --- sunhh
  18. public static boolean isEmpty(final Object obj) {
  19. int strLen;
  20. if (obj == null) {
  21. return true;
  22. } else {
  23. CharSequence cs = obj.toString().trim();
  24. if ((strLen = cs.length()) == 0) {
  25. return true;
  26. } else if (obj.toString().trim().toLowerCase().equals("null")) {
  27. return true;
  28. } else {
  29. for (int i = 0; i < strLen; i++) {
  30. if (Character.isWhitespace(cs.charAt(i)) == false) {
  31. return false;
  32. }
  33. }
  34. }
  35. }
  36. return true;
  37. }
  38. //为null,为"",为 " " --- sunhh
  39. public static boolean isEmptySunhh(final Object obj) {
  40. int strLen;
  41. if (obj == null) {
  42. return true;
  43. } else {
  44. CharSequence cs = obj.toString().trim();
  45. if ((strLen = cs.length()) == 0) {
  46. return true;
  47. } else if (obj.toString().trim().toLowerCase().equals("null")) {
  48. return true;
  49. } else {
  50. for (int i = 0; i < strLen; i++) {
  51. if (Character.isWhitespace(cs.charAt(i)) == false) {
  52. return false;
  53. }
  54. }
  55. }
  56. }
  57. return true;
  58. }
  59. /**
  60. * 空字符串
  61. */
  62. private static final String NULLSTR = "";
  63. /**
  64. * 下划线
  65. */
  66. private static final char SEPARATOR = '_';
  67. /**
  68. * 获取参数不为空值
  69. *
  70. * @param value defaultValue 要判断的value
  71. * @return value 返回值
  72. */
  73. public static <T> T nvl(T value, T defaultValue) {
  74. return value != null ? value : defaultValue;
  75. }
  76. /**
  77. * * 判断一个Collection是否为空, 包含List,Set,Queue
  78. *
  79. * @param coll 要判断的Collection
  80. * @return true:为空 false:非空
  81. */
  82. public static boolean isEmpty(Collection<?> coll) {
  83. return isNull(coll) || coll.isEmpty();
  84. }
  85. /**
  86. * * 判断一个Collection是否非空,包含List,Set,Queue
  87. *
  88. * @param coll 要判断的Collection
  89. * @return true:非空 false:空
  90. */
  91. public static boolean isNotEmpty(Collection<?> coll) {
  92. return !isEmpty(coll);
  93. }
  94. /**
  95. * * 判断一个对象数组是否为空
  96. *
  97. * @param objects 要判断的对象数组
  98. * * @return true:为空 false:非空
  99. */
  100. public static boolean isEmpty(Object[] objects) {
  101. return isNull(objects) || (objects.length == 0);
  102. }
  103. /**
  104. * * 判断一个对象数组是否非空
  105. *
  106. * @param objects 要判断的对象数组
  107. * @return true:非空 false:空
  108. */
  109. public static boolean isNotEmpty(Object[] objects) {
  110. return !isEmpty(objects);
  111. }
  112. /**
  113. * * 判断一个Map是否为空
  114. *
  115. * @param map 要判断的Map
  116. * @return true:为空 false:非空
  117. */
  118. public static boolean isEmpty(Map<?, ?> map) {
  119. return isNull(map) || map.isEmpty();
  120. }
  121. /**
  122. * * 判断一个Map是否为空
  123. *
  124. * @param map 要判断的Map
  125. * @return true:非空 false:空
  126. */
  127. public static boolean isNotEmpty(Map<?, ?> map) {
  128. return !isEmpty(map);
  129. }
  130. /**
  131. * * 判断一个字符串是否为空串
  132. *
  133. * @param str String
  134. * @return true:为空 false:非空
  135. */
  136. public static boolean isEmpty(String str) {
  137. return isNull(str) || NULLSTR.equals(str.trim());
  138. }
  139. /**
  140. * * 判断一个字符串是否为非空串
  141. *
  142. * @param str String
  143. * @return true:非空串 false:空串
  144. */
  145. public static boolean isNotEmpty(String str) {
  146. return !isEmpty(str);
  147. }
  148. /**
  149. * * 判断一个对象是否为空
  150. *
  151. * @param object Object
  152. * @return true:为空 false:非空
  153. */
  154. public static boolean isNull(Object object) {
  155. return object == null;
  156. }
  157. /**
  158. * * 判断一个对象是否非空
  159. *
  160. * @param object Object
  161. * @return true:非空 false:空
  162. */
  163. public static boolean isNotNull(Object object) {
  164. return !isNull(object);
  165. }
  166. /**
  167. * * 判断一个对象是否是数组类型(Java基本型别的数组)
  168. *
  169. * @param object 对象
  170. * @return true:是数组 false:不是数组
  171. */
  172. public static boolean isArray(Object object) {
  173. return isNotNull(object) && object.getClass().isArray();
  174. }
  175. /**
  176. * 去空格
  177. */
  178. public static String trim(String str) {
  179. return (str == null ? "" : str.trim());
  180. }
  181. /**
  182. * 截取字符串
  183. *
  184. * @param str 字符串
  185. * @param start 开始
  186. * @return 结果
  187. */
  188. public static String substring(final String str, int start) {
  189. if (str == null) {
  190. return NULLSTR;
  191. }
  192. if (start < 0) {
  193. start = str.length() + start;
  194. }
  195. if (start < 0) {
  196. start = 0;
  197. }
  198. if (start > str.length()) {
  199. return NULLSTR;
  200. }
  201. return str.substring(start);
  202. }
  203. /**
  204. * 截取字符串
  205. *
  206. * @param str 字符串
  207. * @param start 开始
  208. * @param end 结束
  209. * @return 结果
  210. */
  211. public static String substring(final String str, int start, int end) {
  212. if (str == null) {
  213. return NULLSTR;
  214. }
  215. if (end < 0) {
  216. end = str.length() + end;
  217. }
  218. if (start < 0) {
  219. start = str.length() + start;
  220. }
  221. if (end > str.length()) {
  222. end = str.length();
  223. }
  224. if (start > end) {
  225. return NULLSTR;
  226. }
  227. if (start < 0) {
  228. start = 0;
  229. }
  230. if (end < 0) {
  231. end = 0;
  232. }
  233. return str.substring(start, end);
  234. }
  235. /**
  236. * 格式化文本, {} 表示占位符<br>
  237. * 此方法只是简单将占位符 {} 按照顺序替换为参数<br>
  238. * 如果想输出 {} 使用 \\转义 { 即可,如果想输出 {} 之前的 \ 使用双转义符 \\\\ 即可<br>
  239. * 例:<br>
  240. * 通常使用:format("this is {} for {}", "a", "b") -> this is a for b<br>
  241. * 转义{}: format("this is \\{} for {}", "a", "b") -> this is \{} for a<br>
  242. * 转义\: format("this is \\\\{} for {}", "a", "b") -> this is \a for b<br>
  243. *
  244. * @param template 文本模板,被替换的部分用 {} 表示
  245. * @param params 参数值
  246. * @return 格式化后的文本
  247. */
  248. public static String format(String template, Object... params) {
  249. if (isEmpty(params) || isEmpty(template)) {
  250. return template;
  251. }
  252. return StrFormatter.format(template, params);
  253. }
  254. /**
  255. * 是否为http(s)://开头
  256. *
  257. * @param link 链接
  258. * @return 结果
  259. */
  260. public static boolean ishttp(String link) {
  261. return StringUtils.startsWithAny(link, Constants.HTTP, Constants.HTTPS);
  262. }
  263. /**
  264. * 字符串转set
  265. *
  266. * @param str 字符串
  267. * @param sep 分隔符
  268. * @return set集合
  269. */
  270. public static final Set<String> str2Set(String str, String sep) {
  271. return new HashSet<String>(str2List(str, sep, true, false));
  272. }
  273. /**
  274. * 字符串转list
  275. *
  276. * @param str 字符串
  277. * @param sep 分隔符
  278. * @param filterBlank 过滤纯空白
  279. * @param trim 去掉首尾空白
  280. * @return list集合
  281. */
  282. public static final List<String> str2List(String str, String sep, boolean filterBlank, boolean trim) {
  283. List<String> list = new ArrayList<String>();
  284. if (StringUtils.isEmpty(str)) {
  285. return list;
  286. }
  287. // 过滤空白字符串
  288. if (filterBlank && StringUtils.isBlank(str)) {
  289. return list;
  290. }
  291. String[] split = str.split(sep);
  292. for (String string : split) {
  293. if (filterBlank && StringUtils.isBlank(string)) {
  294. continue;
  295. }
  296. if (trim) {
  297. string = string.trim();
  298. }
  299. list.add(string);
  300. }
  301. return list;
  302. }
  303. /**
  304. * 判断给定的set列表中是否包含数组array 判断给定的数组array中是否包含给定的元素value
  305. *
  306. * @param set 给定的集合
  307. * @param array 给定的数组
  308. * @return boolean 结果
  309. */
  310. public static boolean containsAny(Collection<String> collection, String... array) {
  311. if (isEmpty(collection) || isEmpty(array)) {
  312. return false;
  313. } else {
  314. for (String str : array) {
  315. if (collection.contains(str)) {
  316. return true;
  317. }
  318. }
  319. return false;
  320. }
  321. }
  322. /**
  323. * 查找指定字符串是否包含指定字符串列表中的任意一个字符串同时串忽略大小写
  324. *
  325. * @param cs 指定字符串
  326. * @param searchCharSequences 需要检查的字符串数组
  327. * @return 是否包含任意一个字符串
  328. */
  329. public static boolean containsAnyIgnoreCase(CharSequence cs, CharSequence... searchCharSequences) {
  330. if (isEmpty(cs) || isEmpty(searchCharSequences)) {
  331. return false;
  332. }
  333. for (CharSequence testStr : searchCharSequences) {
  334. if (containsIgnoreCase(cs, testStr)) {
  335. return true;
  336. }
  337. }
  338. return false;
  339. }
  340. /**
  341. * 驼峰转下划线命名
  342. */
  343. public static String toUnderScoreCase(String str) {
  344. if (str == null) {
  345. return null;
  346. }
  347. StringBuilder sb = new StringBuilder();
  348. // 前置字符是否大写
  349. boolean preCharIsUpperCase = true;
  350. // 当前字符是否大写
  351. boolean curreCharIsUpperCase = true;
  352. // 下一字符是否大写
  353. boolean nexteCharIsUpperCase = true;
  354. for (int i = 0; i < str.length(); i++) {
  355. char c = str.charAt(i);
  356. if (i > 0) {
  357. preCharIsUpperCase = Character.isUpperCase(str.charAt(i - 1));
  358. } else {
  359. preCharIsUpperCase = false;
  360. }
  361. curreCharIsUpperCase = Character.isUpperCase(c);
  362. if (i < (str.length() - 1)) {
  363. nexteCharIsUpperCase = Character.isUpperCase(str.charAt(i + 1));
  364. }
  365. if (preCharIsUpperCase && curreCharIsUpperCase && !nexteCharIsUpperCase) {
  366. sb.append(SEPARATOR);
  367. } else if ((i != 0 && !preCharIsUpperCase) && curreCharIsUpperCase) {
  368. sb.append(SEPARATOR);
  369. }
  370. sb.append(Character.toLowerCase(c));
  371. }
  372. return sb.toString();
  373. }
  374. /**
  375. * 是否包含字符串
  376. *
  377. * @param str 验证字符串
  378. * @param strs 字符串组
  379. * @return 包含返回true
  380. */
  381. public static boolean inStringIgnoreCase(String str, String... strs) {
  382. if (str != null && strs != null) {
  383. for (String s : strs) {
  384. if (str.equalsIgnoreCase(trim(s))) {
  385. return true;
  386. }
  387. }
  388. }
  389. return false;
  390. }
  391. /**
  392. * 将下划线大写方式命名的字符串转换为驼峰式。如果转换前的下划线大写方式命名的字符串为空,则返回空字符串。 例如:HELLO_WORLD->HelloWorld
  393. *
  394. * @param name 转换前的下划线大写方式命名的字符串
  395. * @return 转换后的驼峰式命名的字符串
  396. */
  397. public static String convertToCamelCase(String name) {
  398. StringBuilder result = new StringBuilder();
  399. // 快速检查
  400. if (name == null || name.isEmpty()) {
  401. // 没必要转换
  402. return "";
  403. } else if (!name.contains("_")) {
  404. // 不含下划线,仅将首字母大写
  405. return name.substring(0, 1).toUpperCase() + name.substring(1);
  406. }
  407. // 用下划线将原始字符串分割
  408. String[] camels = name.split("_");
  409. for (String camel : camels) {
  410. // 跳过原始字符串中开头、结尾的下换线或双重下划线
  411. if (camel.isEmpty()) {
  412. continue;
  413. }
  414. // 首字母大写
  415. result.append(camel.substring(0, 1).toUpperCase());
  416. result.append(camel.substring(1).toLowerCase());
  417. }
  418. return result.toString();
  419. }
  420. /**
  421. * 驼峰式命名法 例如:user_name->userName
  422. */
  423. public static String toCamelCase(String s) {
  424. if (s == null) {
  425. return null;
  426. }
  427. s = s.toLowerCase();
  428. StringBuilder sb = new StringBuilder(s.length());
  429. boolean upperCase = false;
  430. for (int i = 0; i < s.length(); i++) {
  431. char c = s.charAt(i);
  432. if (c == SEPARATOR) {
  433. upperCase = true;
  434. } else if (upperCase) {
  435. sb.append(Character.toUpperCase(c));
  436. upperCase = false;
  437. } else {
  438. sb.append(c);
  439. }
  440. }
  441. return sb.toString();
  442. }
  443. /**
  444. * 查找指定字符串是否匹配指定字符串列表中的任意一个字符串
  445. *
  446. * @param str 指定字符串
  447. * @param strs 需要检查的字符串数组
  448. * @return 是否匹配
  449. */
  450. public static boolean matches(String str, List<String> strs) {
  451. if (isEmpty(str) || isEmpty(strs)) {
  452. return false;
  453. }
  454. for (String pattern : strs) {
  455. if (isMatch(pattern, str)) {
  456. return true;
  457. }
  458. }
  459. return false;
  460. }
  461. /**
  462. * 判断url是否与规则配置:
  463. * ? 表示单个字符;
  464. * * 表示一层路径内的任意字符串,不可跨层级;
  465. * ** 表示任意层路径;
  466. *
  467. * @param pattern 匹配规则
  468. * @param url 需要匹配的url
  469. * @return
  470. */
  471. public static boolean isMatch(String pattern, String url) {
  472. AntPathMatcher matcher = new AntPathMatcher();
  473. return matcher.match(pattern, url);
  474. }
  475. @SuppressWarnings("unchecked")
  476. public static <T> T cast(Object obj) {
  477. return (T) obj;
  478. }
  479. /**
  480. * 数字左边补齐0,使之达到指定长度。注意,如果数字转换为字符串后,长度大于size,则只保留 最后size个字符。
  481. *
  482. * @param num 数字对象
  483. * @param size 字符串指定长度
  484. * @return 返回数字的字符串格式,该字符串为指定长度。
  485. */
  486. public static final String padl(final Number num, final int size) {
  487. return padl(num.toString(), size, '0');
  488. }
  489. /**
  490. * 字符串左补齐。如果原始字符串s长度大于size,则只保留最后size个字符。
  491. *
  492. * @param s 原始字符串
  493. * @param size 字符串指定长度
  494. * @param c 用于补齐的字符
  495. * @return 返回指定长度的字符串,由原字符串左补齐或截取得到。
  496. */
  497. public static final String padl(final String s, final int size, final char c) {
  498. final StringBuilder sb = new StringBuilder(size);
  499. if (s != null) {
  500. final int len = s.length();
  501. if (s.length() <= size) {
  502. for (int i = size - len; i > 0; i--) {
  503. sb.append(c);
  504. }
  505. sb.append(s);
  506. } else {
  507. return s.substring(len - size, len);
  508. }
  509. } else {
  510. for (int i = size; i > 0; i--) {
  511. sb.append(c);
  512. }
  513. }
  514. return sb.toString();
  515. }
  516. }