简体   繁体   中英

Angular reactive forms pattern validator adding $ to regex and breaking validation

I'm trying to validate a password with the following regex:
^(?=.*[AZ])(?=.*[az])(?=.*[0-9])(?=.{8,}) .
Note that there is no terminating $ char, because that would prevent valid passwords from being accepted. (I'm not sure why the input field doesn't terminate the string).
However, Angular's Validators.pattern adds the end of string char. And therefore my valid passwords fail.
How do I prevent the pattern validator from adding the $ ?
I suppose I could roll my own password validator, but surely there is a better solution...?

EDIT: Passwords that should succeed:

  • Test1234
  • tEst1234
  • tesT1234
  • 1234Test
  • 1234tesT
  • t#St1234

Passwords that should fail:

  • TEST1234
  • test1234
  • tEst123
  • Test123
  • testtest
  • 12345678

Validator declaration:

this.password = new FormControl('', [Validators.required, Validators.pattern('^(?=.*[A-Z])(?=.*[a-z])(?=.*[0-9])(?=.{8,})')]);
this.userForm.addControl('Password', this.password);

You may add a .* at the end, or even revamp the pattern a bit to convert one lookahead into a consuming pattern:

Validators.pattern('(?=.*[A-Z])(?=.*[a-z])(?=.*[0-9]).{8,}')

Or, better, when using a regex for password validation, follow the principle of contrast :

Validators.pattern('(?=[^A-Z]*[A-Z])(?=[^a-z]*[a-z])(?=[^0-9]*[0-9]).{8,}')

Angular will add ^ and $ on both ends of the regex pattern, so the pattern will look like

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

Note it won't add the anchors automatically if you use a regex literal , add them manually:

Validators.pattern(/^(?=[^A-Z]*[A-Z])(?=[^a-z]*[a-z])(?=\D*\d).{8,}$/)

With a regex literal, you may use single backslashes in regex escapes ( /\\d/ to match a digit vs. "\\\\d" in a string literal).

See the regex demo

Details

  • ^ - start of string
  • (?=[^AZ]*[AZ]) - at least 1 uppercase ASCII letter
  • (?=[^az]*[az]) - at least 1 lowercase ASCII letter
  • (?=[^0-9]*[0-9]) - at least 1 ASCII digit
  • .{8,} - any 8 or more chars (other than line break chars)
  • $ - end of string.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM