首頁 > 後端開發 > php教程 > PHP自備方法驗證郵件信箱位址

PHP自備方法驗證郵件信箱位址

*文
發布: 2023-03-18 18:58:01
原創
2326 人瀏覽過

本文主要為大家詳細介紹了PHP自備方法驗證郵箱是否存在,以及PHP自備方法驗證URL、IP是否合法,有興趣的小伙伴們可以參考一下。希望對大家有幫助。

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

filter_var

filter_var是PHP內建的變數過濾的方法, 提供了許多實用的過濾器, 可以用來校驗整數、浮點數、信箱、URL、MAC位址等。

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


$email = "lastchiliarch@163.com";
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
$email = "asb";
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
$email = "1@a.com";
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
登入後複製

輸出:


#
string(21) "lastchiliarch@163.com"
bool(false)
string(7) 1@a.com
登入後複製

對於asb這種非法信箱格式傳回了false , 但對於1@a.com則通過了,還是略有瑕疵啊。

不過一般的正則也通過會認為1@a.com是一個合法的郵箱, 那有啥辦法可以更精準的驗證呢?

checkdnsrr

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

對於1@a.com肯定是MX記錄不存在的。


$email = "lastchiliarch@163.com";
  var_dump(checkdnsrr(array_pop(explode("@",$email)),"MX"));
  $email = "1@a.com";
  var_dump(checkdnsrr(array_pop(explode("@",$email)),"MX"));
登入後複製

輸出:


#
  bool(true)
  bool(false)
登入後複製

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

filter_var+checkdnsrr

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

checkdnsrr進一步判斷。


$email_arr = array("lastchiliarch@163.com", "1@a.com");
  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: 1@a.com
登入後複製

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

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

介紹了郵箱驗證,PHP自帶方法如何驗證郵箱、URL、IP是否合法,以下為大家介紹:

主要還是使用的是filter_var函數

語法
filter_var(variable, filter, options)
variable 必要。規定要過濾的變數。
filter 可選。規定要使用的過濾器的 ID。
options 規定包含標誌/選項的陣列。檢查每個過濾器可能的標誌和選項。

PHP Filters

#Example #1 A filter_var() example


#
<?php
var_dump(filter_var(&#39;bob@example.com&#39;, FILTER_VALIDATE_EMAIL));
var_dump(filter_var(&#39;http://example.com&#39;, FILTER_VALIDATE_URL, FILTER_FLAG_PATH_REQUIRED));
?>
登入後複製

以上程式會輸出:


##

string(15) "bob@example.com"
bool(false)
登入後複製

#相關推薦:

##php檢查數字是奇數或偶數的程式碼

php 檢查檔案或目錄是否存在程式碼總結

##PHP正規表示式的基礎及簡單實例

#

以上是PHP自備方法驗證郵件信箱位址的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板