程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> php判斷郵箱地址是否存在的方法

php判斷郵箱地址是否存在的方法

編輯:PHP綜合

PHP校驗郵箱地址的方法很多, 比較常用的就是自己寫正則了, 不過正則多麻煩, 我PHP自帶了方法做校驗。

filter_var

filter_var是PHP內置的一個變量過濾的方法, 提供了很多實用的過濾器, 可以用來校驗整數、浮點數、郵箱、URL、MAC地址等。

具體的過濾器參考: filters.validate

filter_var如果返回false, 說明變量無法通過過濾器, 也就是不合法了。

$email = "[email protected]";
 
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
 
 
$email = "asb";
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
 
$email = "[email protected]";
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
 
輸出:
 
 
string(21) "[email protected]"
bool(false)
string(7) "[email protected]"

對於asb這種非法郵箱格式返回了false, 但對於[email protected]則通過了,還是略有瑕疵啊。

不過一般的正則也通過會認為[email protected]是一個合法的郵箱, 那有啥辦法可以更精准的驗證呢?

checkdnsrr

checkdnsrr其實是用來查詢指定的主機的DNS記錄的,我們可以借用它來驗證郵箱是否存在。

對於[email protected]肯定是MX記錄不存在的。

$email = "[email protected]";
  var_dump(checkdnsrr(array_pop(explode("@",$email)),"MX"));
  $email = "[email protected]";
  var_dump(checkdnsrr(array_pop(explode("@",$email)),"MX"));
 
  輸出:
  bool(true)
  bool(false)

可以看到, 很完美, 唯一的缺點就是太慢了, 畢竟是要做一次網絡請求。 所以不適合同步對大量的郵箱采用這種做法去校驗。

filter_var+checkdnsrr

我們可以接合filter_var 和checkdnsrr做校驗, 對於絕大多數的非法郵箱肯定會在filter_var的時候就掛掉了, 剩下的再用

checkdnsrr進一步判斷。

$email_arr = array("[email protected]", "[email protected]");
  foreach($email_arr as $email) {
    if (filter_var($email) === false) {
      echo "invalid email: $email \n";
      continue;
    }
 
    if(checkdnsrr(array_pop(explode("@",$email)),"MX") === false) {
      echo "invalid email: $email \n";
      continue;
    }
  }
 
  輸出: invalid email: [email protected]

但要注意的是, 由於只是檢查MX記錄, 所以只能判斷163.com是存在的, 但不能說明lastchiliarch這個用戶是存在的。

想要更精確的判斷郵箱存在, 那只能連接到smtp服務器去驗證了。

下面為大家分享的php郵箱地址正則表達式驗證,具體內容如下

<?php
 header ( "Content-Type: text/html; charset=UTF-8" );
 $reply = "";
 if ( isset($_POST["email_address"]) )
 {
  $email_address = $_POST["email_address"];
  $pattern = "/^([0-9A-Za-z\\-_\\.]+)@([0-9a-z]+\\.[a-z]{2,3}(\\.[a-z]{2})?)$/i";
  if ( preg_match( $pattern, $email_address ) )
  {
   $reply = "您輸入的電子郵件地址合法<br /><br />\n";
   $user_name = preg_replace( $pattern ,"$1", $email_address );
   $domain_name = preg_replace( $pattern ,"$2", $email_address );
   $reply .= "用戶名:".$user_name."<br />\n";
   $reply .= "域名:".$domain_name."<br />\n\n";
  }
  else
  {
   $reply = "您輸入的電子郵件地址不合法";
  }
 }
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="zh" xml:lang="zh">
<head>
<title>電子郵件地址驗證程序</title>
</head>
<body style="text-align: center;">
<h1>電子郵件地址驗證程序</h1>
<form action="#" method="post">
請輸入電子郵件地址:<input name="email_address" type="text" style="width: 300px;" /><br />
<input type="submit" value="驗證電子郵件地址" />
</form>
<?php
 echo $reply;
?>
</body>
</html>

希望大家喜歡這篇文章,對大家有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved