用PHP來驗證Email是否正確
來源:互聯網
上載者:User
有什麼問題請與我聯絡:http://www.webjx.com web@webjx.com
轉載請註明出處
當你在某個論壇上註冊時,通常都有一個 e-mail 地址驗證的功能,當你輸入非法的一個格式時會出現某種錯誤提示資訊的。
我們可以使用下面的規則運算式
ereg("^[a-zA-Z0-9_]+@[a-zA-Z0-9\-]+\.[a-zA-Z0-9\-\.]+$]", $email);
但是上面這個式子的功能是只能檢查字串,不能進行輸出。我們可以進一步利用這個式子來達到返回資訊的功能:
if (eregi("^[a-zA-Z0-9_]+@[a-zA-Z0-9\-]+\.[a-zA-Z0-9\-\.]+$]", $email))
{
return FALSE;
}
下面我們可以進一步來檢測主機名稱,是不是存在:
list($Username, $Domain) = split("@",$email);
if(getmxrr($Domain, $MXHost))
{
return TRUE;
}
else
{
if(fsockopen($Domain, 25, $errno, $errstr, 30))
{
return TRUE;
}
else
{
return FALSE;
}
}
現在我們再把上面的兩個功能用PHP組織起來構成一個函數:
function checkEmail($email)
{ if(eregi("^[a-zA-Z0-9_]+@[a-zA-Z0-9\-]+\.[a-zA-Z0-9\-\.]+$]", $email))
{
return FALSE;
}
list($Username, $Domain) = split("@",$email);
if(getmxrr($Domain, $MXHost))
{
return TRUE;
}
else
{
if(fsockopen($Domain, 25, $errno, $errstr, 30))
{
return TRUE;
}
else
{
return FALSE;
}
}
}
之後我們就可以利用這個函數來檢測是否存在輸入的一個Email了,舉個例子:
if(checkEmail(web@webjx.com) == FALSE)
{
echo "您輸入的E_mail是不正確的.";
}
else
{
echo "輸入的E_mail是正確的.";
}