我正在尝试使用Telerik的RadDataForm控件显示一个简单的登录表单。我可以正确验证电子邮件,但是当我尝试使用RegEx验证器作为密码时,总是失败。我正在使用的正则表达式已在其他地方使用,没有问题。我正在使用的测试密码是“ Tested12”,应该可以通过。为了总结测试,字符串至少应包含一个大写字母,一个小写字母和一个数字。该长度至少应为8个字符。
正则表达式为:
^(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.{8,})
这是我用来定义密码字段的json元数据:
{
name: 'password',
displayName: 'Password',
editor: 'Text',
validators: [{
name: 'RegEx',
params: {
'regEx': '^(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.{8,})',
errorMessage: 'Passwords must be at least 8 characters long and contain numbers, uppercase letters, and lowercase letters.'
}
}]
}
我认为这并不重要,但是我正在Nativescript-Vue项目中使用Nativescript UI中的控件。
答案 0 :(得分:1)
您的正则表达式仅包含前瞻性非消耗模式,它们仅检查字符串中是否存在某些文本,但它们实际上不移动正则表达式索引,也不将匹配的文本放入匹配值中。验证中的正则表达式必须消费整个字符串。
最简单的方法是将长度检查提前转换为使用模式:
'regEx': '^(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9]).{8,}'
^^^^^
实际上,如果您使用对比原则,则可以创建更好的密码正则表达式:
'regEx': '^(?=[^a-z]*[a-z])(?=[^A-Z]*[A-Z])(?=[^0-9]*[0-9]).{8,}'
详细信息
^
-字符串的开头(?=[^a-z]*[a-z])
-(在字符串开头执行一次检查的正向超前)在0+个字符之后(小写ASCII字母除外),必须有小写ASCII字母(?=[^A-Z]*[A-Z])
-(在字符串开头执行一次检查的正向超前)在0+个字符之后(除了大写ASCII字母),必须有一个大写ASCII字母(?=[^0-9]*[0-9])
-(在字符串开头执行一次检查的正向超前)在除数字以外的0+个字符之后,必须有一个数字.{8,}
-除换行符以外的8个或更多字符。