下面我来总结了在php邮箱验证的正则表达式以及还可以checkdnsrr函数来验证你输入的邮箱是否是有效的哦,这样可以更好的过滤到无效邮箱地址哦。
域名由各国文字的特定字符集、英文字母、数字及“-”(即连字符或减号)任意组合而成, 但开头及结尾均不能含有“-”,“-”不能连续出现 。 域名中字母不分大小写。域名最长可达60个字节(包括后缀.com、.net、.org等)。
/^[a-z]([a-z0-9]*[-_]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+[.][a-z]{2,3}([.][a-z]{2})?$/i;/内容/i 构成一个不区分大小写的正则表达式
代码如下:
- $email = "tanklo_--vehy@yahoo.com.cn";
- function check_email($email) {
- $pattern_test = "/([a-z0-9]*[-_.]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+[.][a-z]{2,3}([.][a-z]{2})?/i";
- return preg_match($pattern_test,$email);
- }
- echo check_email($email);
上面的只能简单的验证邮件格式,下面一个更具体验证方法,PHP如何验证,代码如下:
- <?
-
- function valid_email($email) {
-
- if (!ereg("^[^@]{1,64}@[^@]{1,255}$", $email)) {
-
- return false;
- }
-
- $email_array = explode("@", $email);
- $local_array = explode(".", $email_array[0]);
- for ($i = 0; $i < sizeof($local_array); $i++) {
- if (!ereg("^(([A-Za-z0-9!#$%&'*+/=?^_`{|}~-][A-Za-z0-9!#$%&'*+/=?^_`{|}~.-]{0,63})|("[^(\|")]{0,62}"))$", $local_array[$i])) {
- return false;
- }
- }
- if (!ereg("^[?[0-9.]+]?$", $email_array[1])) {
- $domain_array = explode(".", $email_array[1]);
- if (sizeof($domain_array) < 2) {
- return false;
- }
- for ($i = 0; $i < sizeof($domain_array); $i++) {
- if (!ereg("^(([A-Za-z0-9][A-Za-z0-9-]{0,61}[A-Za-z0-9])|([A-Za-z0-9]+))$", $domain_array[$i])) {
- return false;
- }
- }
- }
- return true;
- }
-
-
- if(!valid_email($myeml)){
- echo"<script>alert('Please enter a valid e-mail address');location.href='javascript:history.back()'</script>";
- break;
- }
- ?>
无意中就发现checkdnsrr函数那里就有了更精妙的例子,分享给大家,代码如下:
- <?php
- function validate_email($email){
- $exp = "^[a-z'0-9]+([._-][a-z'0-9]+)*@([a-z0-9]+([._-][a-z0-9]+))+$";
- if(eregi($exp,$email)){
- if(checkdnsrr(array_pop(explode("@",$email)),"MX")){
- return true;
- }else{
- return false;
- }
- }else{
- return false;
- }
- }
- ?>
(责任编辑:admin) |