大发体育娱乐在线-大发体育娱乐官方网站-大发体育娱乐登录网址
做最好的网站

奇葩写法,PHP验证邮件地址实例

来源:http://www.dfwstonefabricators.com 作者:关于计算机 人气:136 发布时间:2019-09-28
摘要:  起头写的一个PHP表微单子邮件发送程序,个中使用如下方法来验证电子邮件地址格式是还是不是正确: 电子邮件验证只怕是中最常用的网页表单验证,此代码除了表明电子邮件地址,

 

起头写的一个PHP表微单子邮件发送程序,个中使用如下方法来验证电子邮件地址格式是还是不是正确:

电子邮件验证只怕是中最常用的网页表单验证,此代码除了表明电子邮件地址,也得以采取检查邮件域所属 DNS 中的 MX 记录,使邮件验证作用更是强有力。

 代码如下

function is_valid_email($email, $test_mx = false)
{
if(eregi("^([_a-z0-9-]+)(.[_a-z0-9-]+)*@([a-z0-9-]+)(.[a-z0-9-]+)*(.[a-z]{2,4})$", $email))
if($test_mx)
{
list($username, $domain) = split("@", $email);
return getmxrr($domain, $mxrecords);
}
else
return true;
else
return false;
}

eregi("^[_a-z0-9-]+(.[_a-z0-9-]+)*@[a-z0-9_-]+.[a-z0-9_-]+.*", $email)

新生察觉邻近于将.误写为,的电子邮件地址也能经过认证,比方user@126,com。经过检查,发现它实际只验证了顾客名部分,所以又在英特网找到一个学科,个中交付的例子如下:

 代码如下

eregi('^[_a-z0-9-]+(.[_a-z0-9-]+)*@[a-z0-9-]+(.[a-z0-9-]+)*$',$email)

透过检查,开掘电子邮件地址user@126,com依然能够由此它的印证。找到了一个示范:

 代码如下

eregi("^[_.0-9a-z-]+@([0-9a-z][0-9a-z-]+.)+[a-z]{2,3}$",$str)

以此看起来更为客观一些,因为它对后缀名称实行了验证,尽管今后出现了4个字符以上的一流域名,不过只要求稍加修改就可以。可是电子邮件地址user@xxx,com 111cn.net还是能够因此认证,留心检查后发觉是因为未有对.举行转义导致。于是对它稍做修改:

 代码如下

eregi("^[_.0-9a-z-]+@([0-9a-z][0-9a-z-]+.)+[a-z]{2,4}$)

固然如此它对顾客名的自己商量要越来越宽松一些,不过以后利用它的功能就如不错。

例1

 代码如下

<?php
function is_valid_email($email, $test_mx = false)
{
if(eregi("^([_a-z0-9-]+)(.[_a-z0-9-]+)*@([a-z0-9-]+)(.[a-z0-9-]+)*(.[a-z]{2,4})$", $email))
if($test_mx)
{
list($username, $domain) = split("@", $email);
return getmxrr($domain, $mxrecords);
}
else
return true;
else
return false;
}
?>

例2(自身写的)

 代码如下

function is_valid_email_address($email){
$qtext = '[^//x0d//x22//x5c//x80-//xff]';
$dtext = '[^//x0d//x5b-//x5d//x80-//xff]';
$atom = '[^//x00-//x20//x22//x28//x29//x2c//x2e//x3a-//x3c'.
'//x3e//x40//x5b-//x5d//x7f-//xff]+';
$quoted_pair = '//x5c[//x00-//x7f]';
$domain_literal = "//x5b($dtext|$quoted_pair)*//x5d";
$quoted_string = "//x22($qtext|$quoted_pair)*//x22";
$domain_ref = $atom;
$sub_domain = "($domain_ref|$domain_literal)";
$word = "($atom|$quoted_string)";
$domain = "$sub_domain(//x2e$sub_domain)*";
$local_part = "$word(//x2e$word)*";
$addr_spec = "$local_part//x40$domain";
return preg_match("!^$addr_spec$!", $email) ? 1 : 0;
}

本文由大发体育娱乐在线发布于关于计算机,转载请注明出处:奇葩写法,PHP验证邮件地址实例

关键词:

最火资讯