我需要一个正则表达式来检查:

密码至少包含八个字符,包括至少一个数字,包括小写和大写字母以及特殊字符,例如#、?、!。

它不能是您的旧密码,也不能包含您的用户名、“密码”或“网站名称”

这是我的验证表达式,用于八个字符,包括一个大写字母、一个小写字母和一个数字或特殊字符。

(?=^.{8,}$)((?=.*\d)|(?=.*\W+))(?![.\n])(?=.*[A-Z])(?=.*[a-z]).*$"

如果密码必须是八个字符,包括一个大写字母、一个特殊字符和字母数字字符,我怎么写?


当前回答

没有直接回答这个问题,但它真的必须是正则表达式吗?

我曾经做过很多Perl,并习惯于用正则表达式解决问题。然而,当它们变得更加复杂时,你需要编写几十个单元测试来消除所有这些小bug。

此外,正则表达式通常比命令式或函数式解决方案慢几倍。

例如,以下(不是非常FP)Scala函数解决原始问题的速度大约是最流行答案的正则表达式的三倍。它的作用也很清楚,您根本不需要单元测试:

def validatePassword(password: String): Boolean = {
  if (password.length < 8)
    return false

  var lower = false
  var upper = false
  var numbers = false
  var special = false

  password.foreach { c =>
    if (c.isDigit)       numbers = true
    else if (c.isLower)  lower = true
    else if (c.isUpper)  upper = true
    else                 special = true
  }

  lower && upper && numbers && special
}

其他回答

演示:

函数password_check(){pass=document.getElementById(“密码”).value;console.log(通过);正则表达式=/^(?=.*[a-z])(?=..*[a-z])((?=*.*\d)(?=.*[@$!%*?&])[a-Za-z\d@$!%*?&]{8,}$/;if(regex.exec(pass)==null){警报('有效密码!')}其他{console.log(“有效”);}}<input type=“text”id=“password”value=“Sample@1"><input type=“button”id=“submit”onclick=“password_check()”value=“submit“>

我们可以通过使用HTML5来做到这一点。

在模式属性中使用以下代码,

pattern="(?=^.{8,}$)((?=.*\d)(?=.*\W+))(?![.\n])(?=.*[A-Z])(?=.*[a-z]).*$"

它将完美地工作。

 

✅ 以下4个正则表达式模式可以帮助您编写几乎所有的密码验证

 

 

模式1:

 

密码必须包含1到9之间的一个数字、一个小写字母、一个大写字母、一种特殊字符、无空格,并且长度必须为8-16个字符。

/^(?=.*[0-9])(?=.*[a-z])(?=.*[A-Z])(?=.*\W)(?!.* ).{8,16}$/

 

说明:

 

(?=.*[0-9])表示密码必须包含一个从1到9的数字。

 

(?=.*[a-z])表示密码必须包含一个小写字母。

 

(?=.*[A-Z])表示密码必须包含一个大写字母。

 

(?=.*\W)表示密码必须包含一个特殊字符。

 

.{8,16}表示密码长度必须为8-16个字符。我们必须在正则表达式的末尾,就在$符号之前使用它。

 

什么是^和$:

 

^表示字符串的开头。$表示字符串的结尾。

如果不使用这些^&$,正则表达式将无法确定密码的最大长度。在上面的示例中,我们有一个条件,即密码不能超过16个字符,为了使该条件有效,我们使用了这些^&$

 

删除最大长度限制:

 

而不是{8,16},如果我们使用。{8,},这意味着密码长度必须至少为8个字符。因此,不存在检查密码最大长度的任何条件。

 

不接受任何数字(数字):

 

如果使用(?!.*[0-9])而不是(?=.*[0-10]),则意味着密码不能包含1-9之间的任何数字(与(?=.*[0-0])的区别是使用!而不是=)

 

不接受任何特殊字符:

 

如果我们使用(?!.*\W)而不是(?=.*\W),则意味着密码不能包含任何特殊字符(与(?=.*\W的区别在于使用!而不是=)

 

数字(数字)的替代语法:

 

我们可以使用(?=.*\d)代替(?=.*\d)。(?=..*\d)也意味着密码必须包含1到9之间的一个数字。

 

 

模式2:

 

密码必须包含1到9之间的一个数字、一个小写字母、一个大写字母、一条下划线,但不能包含其他特殊字符、空格,并且长度必须为8-16个字符。

/^(?=.*[0-9])(?=.*[a-z])(?=.*[A-Z])(?=.*_)(?!.*\W)(?!.* ).{8,16}$/

 

与模式1的区别

 

这里,我们使用了模式1中没有的(?=.*_)。

 

(?=.*_)(?!.*\W)表示密码必须包含下划线,但不能包含任何其他特殊字符。

 

模式3:

 

密码必须包含1到9之间的一个数字、一个小写字母、一个大写字母、一条下划线、无空格,并且长度必须为8-16个字符。除下划线外,任何其他特殊字符的使用都是可选的。

/^(?=.*[0-9])(?=.*[a-z])(?=.*[A-Z])(?=.*_)(?!.* ).{8,16}$/

 

与模式2的区别

 

这里,我们没有使用(?!.*\W)模式2上的内容。

 

但它仍然具有(?=.*_)

 

通过删除(?!.*\W),特殊字符已成为可选字符。现在,需要一个下划线,但可以使用或不使用任何其他特殊字符,因为它是可选的。

 

模式4:

 

密码必须包含1到9之间的一个数字、一个小写字母、一个大写字母和一个下划线,并且长度必须为8-16个字符。任何其他特殊字符的使用和空格的使用都是可选的。

/^(?=.*[0-9])(?=.*[a-z])(?=.*[A-Z]).{8,16}$/

 

与模式3的区别

 

这里,我们没有使用模式3中的(?=.*_)&(?!.*)。

 

通过删除(?=.*_),不再强制传递一个下划线。现在,传递特殊字符是可选的。

 

通过删除(?!.*),空间的使用也变得可选。

对于需要以下内容的更严格的验证:

至少一个大写字符至少一个小写字符至少一个数字至少有一个符号/特殊字符@$!%*#&^_-最少8个字符/数字

Regex公司:

/(?=.*\d)(?=.*[a-z])(?=.*[A-Z])(?=.*[@$!%*#?&^_-]).{8,}/

我希望它能帮助更严格的人。

导入JavaScript文件jquery.validate.min.js。

您可以使用此方法:

$.validator.addMethod("pwcheck", function (value) {
    return /[\@\#\$\%\^\&\*\(\)\_\+\!]/.test(value) && /[a-z]/.test(value) && /[0-9]/.test(value) && /[A-Z]/.test(value)
});

至少一个大写英文字母至少一个小写英文字母至少一个数字至少一个特殊字符