匹配数字和字母的正则表达式

一个用户注册功能的密码有如下要求:由数字和字母组成,并且要同时含有数字和字母,且长度要在8-16位之间。

如何分析需求?拆分!这就是软件设计的一般思路了。于是乎,拆分需求如下:

  • 不能全部是数字
  • 不能全部是字母
  • 必须是数字或字母

只要能同时满足上面3个要求就可以了,写出来如下:

 

1 String regex = "^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{8,16}$";       

 

分开来注释一下:

  • ^ : 匹配一行的开头位置
  • (?![0-9]+$) :预测该位置后面不全是数字
  • (?![a-zA-Z]+$) :预测该位置后面不全是字母
  • [0-9A-Za-z] {8,16} :由8-16位数字或这字母组成
  • $ :匹配行结尾位置

注:(?!xxxx) 是正则表达式的负向零宽断言一种形式,标识预该位置后不是xxxx字符。

posted @ 2014-07-30 18:47  bluepoint2009  阅读(5350)  评论(0编辑  收藏  举报