加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

正则表达式(靓号过滤)

发布时间:2020-12-14 00:44:26 所属栏目:百科 来源:网络整理
导读:一般公司在开发一类对的号码时,会预留一些号码给以后升级的会员使用,比如旺旺靓号,QQ号等,采用正则表达式实现较好,通过规则引擎的后台页面做成实时可配置的也是不错的选择。 一. 一般会有如下的正则需求 参考文档:菜鸟教程(正则表达式) 代码如下: Jav

一般公司在开发一类对的号码时,会预留一些号码给以后升级的会员使用,比如旺旺靓号,QQ号等,采用正则表达式实现较好,通过规则引擎的后台页面做成实时可配置的也是不错的选择。

一. 一般会有如下的正则需求

参考文档:菜鸟教程(正则表达式)

代码如下:

Java代码
  1. publicclassCreditCodeRegexValidateStategyServiceImplimplementsCreditCodeValidateStategyService{
  2. privatestaticList<String>levitPatterns;
  3. staticsynchronizedvoidinit(){
  4. if(levitPatterns==null){
  5. levitPatterns=newArrayList<String>();
  6. }else{
  7. return;
  8. }
  9. //手机号、生日号、跟公司业务相关的号码
  10. levitPatterns.add("^(0|13|15|18|168|400|800)[0-9]*$");
  11. levitPatterns.add("^d{2}(0[1-9]|1[0-2])(0[1-9]|[12][0-9]|3[01])$");
  12. levitPatterns.add("^d*(1688|2688|2088|2008|5188|10010|10001|666|888|668|686|688|866|868|886|999)d*$");
  13. //重复号码,镜子号码
  14. levitPatterns.add("^(<a>d)(d)(d)123$");
  15. </a>levitPatterns.add("^(d)(d)(d)321$");
  16. //AABB
  17. levitPatterns.add("^d*(d)1(d)2d*$");
  18. //AAABBB
  19. levitPatterns.add("^d*(d)11(d)22d*$");
  20. //ABABAB
  21. levitPatterns.add("^(d)(d)121212$");
  22. //ABCABC
  23. levitPatterns.add("^(d)(d)(d)123$");
  24. //ABBABB
  25. levitPatterns.add("^(d)(d)2122$");
  26. //AABAAB
  27. levitPatterns.add("^(d)1(d)112$");
  28. //4-8位置重复
  29. levitPatterns.add("^d*(d)1{2,}d*$");
  30. //4位以上位递增或者递减(7890也是递增)
  31. levitPatterns.add("(?:(?:0(?=1)|1(?=2)|2(?=3)|3(?=4)|4(?=5)|5(?=6)|6(?=7)|7(?=8)|8(?=9)|9(?=0)){2,}|(?:0(?=9)|9(?=8)|8(?=7)|7(?=6)|6(?=5)|5(?=4)|4(?=3)|3(?=2)|2(?=1)|1(?=0)){2,})d");
  32. //不能以518、918结尾
  33. levitPatterns.add("^[0-9]*(518|918)$");
  34. @Override
  35. booleanisAllow(Stringinput){
  36. Assert.notNull(input);
  37. return!RegexUtil.contains(input,levitPatterns);
  38. static{
  39. init();
  40. }

对于以上正则,前面的大多人都很熟悉了,这里主要讲位置查找和前后向查找,即如下两种号码的判断

levitPatterns.add("^(d)(d)2122$");

位置查找:2122这部分代表的 第一个A 位置是1 第二个B位置是2,重复B则用2标识

后向查找 ("(?:(?:0(?=1)| 对于连续号码,?=表示往后看,要判断0后面是1吗,1后面是2吗,如此反复可以得到连续号码

二. 使用 org.apache.oro.text.regex.Pattern 代替 java自身带的partern,

为什么抛弃java现有的API不用,而使用perl5规范的正则库呢?他是最全面的正则表达式API,全面兼容perl5,同时也是优化的最好的API之一,在未来的JDK版本中可能会看到的。

上面程序调用的正则代码如下:

classRegexUtil{
  • staticPatternCompilercompiler=newPerl5Compiler();
  • staticPatternMatchermatcher=newPerl5Matcher();
  • staticPatternpattern=null;
  • /**
  • *根据正则过滤条件过滤
  • *
  • *@paraminput
  • *@paramlevitPatterns
  • *@return
  • *@throwsMalformedPatternException
  • */
  • booleancontains(Stringinput,StringpatternString){
  • try{
  • pattern=compiler.compile(patternString);
  • if(matcher.contains(input,pattern)){
  • returntrue;
  • catch(MalformedPatternExceptione){
  • false;
  • *根据批量正则过滤条件过滤
  • *@parampatternStrings
  • for(Iterator<String>lt=patternStrings.listIterator();lt.hasNext();){
  • if(contains(input,(String)lt.next())){
  • continue;
  • }
  • (编辑:李大同)

    【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

      推荐文章
        热点阅读