亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PHP自帶方法驗證郵箱是否存在

 更新時間:2016年02月01日 12:18:25   投稿:lijiao  
這篇文章主要為大家詳細介紹了PHP自帶方法驗證郵箱是否存在,以及PHP自帶方法驗證URL、IP是否合法,感興趣的小伙伴們可以參考一下

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

filter_var

filter_var是PHP內置的一個變量過濾的方法, 提供了很多實用的過濾器, 可以用來校驗整數(shù)、浮點數(shù)、郵箱、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做校驗, 對于絕大多數(shù)的非法郵箱肯定會在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函數(shù)。

語法
filter_var(variable, filter, options)
variable 必需。規(guī)定要過濾的變量。
filter 可選。規(guī)定要使用的過濾器的 ID。
options 規(guī)定包含標志/選項的數(shù)組。檢查每個過濾器可能的標志和選項。

PHP Filters

Example #1 A filter_var() example

<?php

var_dump(filter_var('bob@example.com', FILTER_VALIDATE_EMAIL));

var_dump(filter_var('http://example.com', FILTER_VALIDATE_URL, FILTER_FLAG_PATH_REQUIRED));

?>

以上例程會輸出:

string(15) "bob@example.com"
bool(false)

以上就是本文的全部內容,希望對大家進行php郵箱驗證有所幫助。

相關文章

最新評論