请教一个校验密码的正则

要求是需至少包含小写字母、大写字母、数字、特殊字符中的两种,且长度不少于8,请正则大神临幸,感谢

阅读 4.6k
4 个回答

一个正则就可以搞定:

var patten = /^(?![a-z]{8,}$)(?![A-Z]{8,}$)(?!\d{8,}$)(?![!@#\$%]{8,}$)[a-zA-Z\d!@#\$%]{8,}$/
patten.test('a2b$cdabABa') //true
patten.test('aaaabbbbs') //false

解释一下,

[a-zA-Z\d!@#\$%]{8,}$ 是正则表达式主体,特殊符号你还可以自己加,目前只支持 !@#\$%
(?![a-z]{8,}$) 是否定断言,表示不能全是小写字母,后面类似

可以分两步处理。

先验证密码是由(小写字母,大写字母,数组,英文特殊符号)中任意字符组成,且长度不少于8。

'abCD12;:'.macth(/^[\u0021-\u007e]{8,}$/);

再验证密码中是否至少包含四种类型中的两种。

// 计算密码中包含了几种类型的字符
function chkPwd (str) {
  var typeNum = 0;
  if (str.match(/[a-z]/)) {
    typeNum += 1;
  }
  if (str.match(/[A-Z]/)) {
    typeNum += 1;
  }
  if (str.match(/[0-9]/)) {
    typeNum += 1;
  }
  if (str.match(/[\u0021-\u002f\u003a-\u0040\u005b-\u0060\u007b-\u007e]/)) {
    typeNum += 1;
  }
  return typeNum;
}

这个是一个排除的问题:
首先确定一个大的集合(长度在8位以上的任意字符串):
.{8,}
然后排除仅仅包含一种类型的集合,并加上限制条件,剩下来的就是满足要求的:
1) 排除全是数字

/(?!\d{8,})/

2) 排除全是小写字母

/(?![a-z]{8,})/

3) 排除全是大写字母

/(?![A-Z]{8,})/

4) 排除全是特殊字符

/(?!\s{8,})/ ---- (以空格为例子)

5) 长度在8位及8位以上,得到

/(?!\d{8,})(?![a-z]{8,})(?![A-Z]{8,})(?!\s{8,}).{8,}/

楼主你看这个是你要的吗?
补充一下,楼下那个的正则其实要比我写的好,我这边可以当做思路补充。

参考地址:
http://www.cnblogs.com/iyangy...
http://blog.csdn.net/lcore/ar...

百度好多答案的,^(?!\d+$)(?![a-zA-Z]+$)(?![^a-zA-Z\d]+$)\S{8,}$判断不纯为某一类就可以了

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题