how to get strong email validation REGEX [duplicate] - regex

This question already has answers here:
Closed 10 years ago.
Possible Duplicate:
Using a regular expression to validate an email address
I am using email address validation in my code and for that I am using a Regex.
Can anyone suggests me a regex which will not accept email addresses eg. abc#def.commmmmm or abc#xyz.com.com.com or abc#gmail.c.
Please help me.
thanks
any information is valuable for me.

REGEXP =
/^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))#((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i,
i have used in validation engine as well as custom js file.

Related

Angular 6 email regex [duplicate]

This question already has answers here:
How can I validate an email address in JavaScript?
(79 answers)
Closed 4 years ago.
I want to validate all email inputs on my app with regex. But there is a problem, all the regex I have found allow emails with no TLD. I want a regex that can help me reject emails such as testing#testing,
Examples:
testing#testing.com should be valid
testing#testing.co.us should be valid
testing#testing should not be valid
The current regex I use is :
^([a-zA-Z0-9_-.]+)#(([[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.)|(([a-zA-Z0-9-]+.)+))([a-zA-Z]{2,4}|[0-9]{1,3})$
But it accepts testing#testing for example, and that is not what I want.
How would I go about validating emails and rejecting ones without TLD
This is the regex which does what you want:
[A-Za-z0-9._%-]+#[A-Za-z0-9._%-]+\\.[a-z]{2,3}

Regex to extract emails not working [duplicate]

This question already has answers here:
How can I validate an email address using a regular expression?
(79 answers)
Closed 7 years ago.
I am trying to extract all the email addresses from pages like this
http://www.quiltguilds.com/alabama.htm
I am using the following RegEX to extract all the emails.
\w+#\w*\.\w*
While this works at online Regex checkers, this isn't working with the import.io application where I am trying to use this to extract all emails.
Can someone kindly review the Regex and confirm if this one would work for extracting just email addresses from a block of text
Many thanks
You can use the following regex:
\S+\#\S+

Regular expression for complicated email [duplicate]

This question already has answers here:
How can I validate an email address using a regular expression?
(79 answers)
Closed 8 years ago.
I want an regex for email that starts with numbers and letters.
My regex is
/^[a-zA-Z0-9._-]+#[a-zA-Z0-9.-]+\.[a-zA-Z]{2,4}$/
What is wrong in this? It allows ._- from start and in between. But I don't want this
Valid emails = s#gmail.com, s.p#y.com, s_p123#g.com
Invalid emails = ....s#g.com, s---g#g.com, s...#g.com, 44s..p#g.com, ----s#g.com
Does anyone know how this can be done?
So you dont want to have more than one ._- in your regex? And also it shall not start with ._- Try it this way:
^[a-zA-Z0-9]+[._-]?[a-zA-Z0-9]*#[a-zA-Z0-9.-]+.[a-zA-Z]{2,4}
It works for your examples, although im not really sure what email-syntax you really want to test for.
Perhaps you want to use one of many pre written examples in the web (just google ;) )

REGEX email matching [duplicate]

This question already has answers here:
How can I validate an email address using a regular expression?
(79 answers)
Closed 8 years ago.
I have a JAVA string that is being used to validate proper email addresses.
^[\\w'-]+(\\.[\\w'-]+)*#[A-Za-z0-9]+([.-][A-Za-z0-9]+)*(\\.[A-Za-z]{2,})$
I want to user to be able to leave the address blank and not get an error message. How is this possible?
Since you didn't provide any other code or specify what language you were using, the best I can suggest is:
(?:^[\\w'-]+(\\.[\\w'-]+)*#[A-Za-z0-9]+([.-][A-Za-z0-9]+)*(\\.[A-Za-z]{2,})$)|(?:^$)
Which will match an e-mail or an empty string.
If you have an expression you want to make optional allowing empty string to match you could use any of the following:
^(?:regex)?\z
^\z|^regex\z

Regexp to find hostname and subdomain from email address [duplicate]

This question already has answers here:
Closed 10 years ago.
Possible Duplicate:
Parse email addresses for “from” and “to” fields in Ruby
Given an email address of the form root#host.sub.domain.com, what is the regular expression to get the hostname and the subdomain as two individual variables? I mean $1='host'and $2='sub'?
You help is greatly appreciated :)
EDIT I should say I'm asking about a regular expression to do this, no Ruby code. This is to be used in a postfix configuration file, so I need a regexp. I mistakenly talked about Ruby earlier. My fault, sorry for the confusion.
Non-greedy groups are your friend. They match just what you need:
^(?:.*?)#(.*?)\.(.*?)\.(?:.*?)\.(?:.*?)$