-
-
Notifications
You must be signed in to change notification settings - Fork 2.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Failing email strings #258
Comments
These non valid emails will pass as valid: var notValid = [
'z@co.c',
'z@co.comm',
'a-very-long-email-over-161-chars@ratar.lorem.ipsum.rata.lorem.ipsum.rata.' +
'lorem.ipsum.rata.lorem.ipsum.rata.lorem.ipsum.rata.lorem.ipsum.rata.' +
'lorem.ipsum.rata.com'
]; |
I can't seem to find any references to a double quote being allowed in email addresses. Do you have a link to a relevant RFC? From the stackoverflow and wikipedia articles I've found it doesn't look like it's allowed. Do the RFC's include a length restriction? As for the invalid TLDs that are passing, it doesn't currently check whether the TLD is valid or not. The list of TLDs would bulk up the size a fair bit and the new custom TLDs will land soon so there's not much point including them. I might make a note in the README saying that you should also check whether the domain has an MX record, etc. as an extra validation step. |
I was surprised to find that these are valid emails too. You can verify with multiple ways, i just do a telnet to an smtp server and check the responses on the For the wrongfully passing emails, the first sample using a single char as TLD is an easy reject. I used to have a regex multiplier rule of {2,3} for the TLD but after checking the TLD list at wikipedia things are a bit more hairy... I'd never suggest including all the TLDs.... SMTPs seem to accept any email address regardless of TLD, which is understandable (avoiding a DNS query). So that's on you to decide how to handle. I also found that the max allowed size for an email is:
Source: http://www.rfc-editor.org/errata_search.php?rfc=3696&eid=1690 |
For rigorous battle-tested email validation used by a high-volume email host, see Perl's Email::Valid, with the "Source" link here: https://metacpan.org/pod/Email::Valid While crazy-long RFC-standard Regex usually isn't wasn't you want, the details how the username and domain parts are validated may be of interest. The rules end up being surprisingly loose to accommodate all the valid edge cases. Fully RFC-compliant email validation would likely include cases you don't want, like allow bare usernames (for local area email), or using IP addresses instead of domain names. |
While developing some tests, I found that also this email address (part of the validator.normalizeEmail test cases) fails the validator.isEmail test: Apparently, it's double/triple dots that make it fail. Also, with the new gTLDs, maybe you should support also emails like "user@hostname"? (e.g. "admin@google") |
I also tested on this: |
Email validation is hard. PRs are always welcome :) |
http://www.regular-expressions.info/email.html Be ready to freak out.
|
@ipeisong: asdf@asdf.com.asd.fasd.f.asdf.asd.fa.xn--sdf-x68do18h is a valid email address according to RFC 822. You can check it against the RFC here: |
It seems so, that It may be a design decision as well, but in this case it would be nice to mention in the README, since browsers started allowing them with Update: Meanwhile |
@andyskw you can use |
@thanpolas the emails you gave as examples now validate correctly: > validator.isEmail('"Abc\\@def"@example.com')
true
> validator.isEmail('"Fred Bloggs"@example.com')
true
> validator.isEmail('"Joe\\Blow"@example.com')
true
> validator.isEmail('"Abc@def"@example.com')
true
> validator.isEmail('z@co.c')
false The remaining two that validate incorrectly are: > validator.isEmail('z@co.comm')
true
> validator.isEmail('a-very-long-email-over-161-chars@ratar.lorem.ipsum.rata.lorem.ipsum.rata.lorem.ipsum.rata.lorem.ipsum.rata.lorem.ipsum.rata.lorem.ipsum.rata.lorem.ipsum.rata.com')
true Some thoughts:
|
Yey! Thank you @chriso! Re length:
Source: http://www.rfc-editor.org/errata_search.php?rfc=3696&eid=1690 |
Is it ok? > validator.isEmail("florian_hartmann@gmail.com");
false
|
@frontendmonster florian_hartmann@gmail.com is not a valid gmail address. |
@tux-tn @frontendmonster You forgot '+'. The + character is totally valid in gmail address. |
it's a special character for sub addresses and yes it's a valid character in validator.js |
I used to have the following valid emails in my test suite,
validator.isEmail()
will reject them:I know they look weird, but they are valid email addresses.
The text was updated successfully, but these errors were encountered: