PHP自帶方法驗(yàn)證郵箱是否存在
PHP校驗(yàn)郵箱地址的方法很多, 比較常用的就是自己寫(xiě)正則了, 不過(guò)正則多麻煩, 我PHP自帶了方法做校驗(yàn)。
filter_var
filter_var是PHP內(nèi)置的一個(gè)變量過(guò)濾的方法, 提供了很多實(shí)用的過(guò)濾器, 可以用來(lái)校驗(yàn)整數(shù)、浮點(diǎn)數(shù)、郵箱、URL、MAC地址等。
filter_var如果返回false, 說(shuō)明變量無(wú)法通過(guò)過(guò)濾器, 也就是不合法了。
$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
對(duì)于asb這種非法郵箱格式返回了false, 但對(duì)于1@a.com則通過(guò)了,還是略有瑕疵啊。
不過(guò)一般的正則也通過(guò)會(huì)認(rèn)為1@a.com是一個(gè)合法的郵箱, 那有啥辦法可以更精準(zhǔn)的驗(yàn)證呢?
checkdnsrr
checkdnsrr其實(shí)是用來(lái)查詢指定的主機(jī)的DNS記錄的,我們可以借用它來(lái)驗(yàn)證郵箱是否存在。
對(duì)于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)
可以看到, 很完美, 唯一的缺點(diǎn)就是太慢了, 畢竟是要做一次網(wǎng)絡(luò)請(qǐng)求。 所以不適合同步對(duì)大量的郵箱采用這種做法去校驗(yàn)。
filter_var+checkdnsrr
我們可以接合filter_var 和checkdnsrr做校驗(yàn), 對(duì)于絕大多數(shù)的非法郵箱肯定會(huì)在filter_var的時(shí)候就掛掉了, 剩下的再用
checkdnsrr進(jìn)一步判斷。
$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是存在的, 但不能說(shuō)明lastchiliarch這個(gè)用戶是存在的。
想要更精確的判斷郵箱存在, 那只能連接到smtp服務(wù)器去驗(yàn)證了。
介紹了郵箱驗(yàn)證,PHP自帶方法如何驗(yàn)證郵箱、URL、IP是否合法,下面為大家介紹:
主要還是使用的是filter_var函數(shù)。
語(yǔ)法
filter_var(variable, filter, options)
variable 必需。規(guī)定要過(guò)濾的變量。
filter 可選。規(guī)定要使用的過(guò)濾器的 ID。
options 規(guī)定包含標(biāo)志/選項(xiàng)的數(shù)組。檢查每個(gè)過(guò)濾器可能的標(biāo)志和選項(xiàng)。
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)); ?>
以上例程會(huì)輸出:
string(15) "bob@example.com" bool(false)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家進(jìn)行php郵箱驗(yàn)證有所幫助。
- php實(shí)現(xiàn)驗(yàn)證郵箱格式的代碼實(shí)例
- PHP利用緩存處理用戶注冊(cè)時(shí)的郵箱驗(yàn)證,成功后用戶數(shù)據(jù)存入數(shù)據(jù)庫(kù)操作示例
- 實(shí)例講解PHP驗(yàn)證郵箱是否合格
- PHP自帶方法驗(yàn)證郵箱、URL、IP是否合法的函數(shù)
- PHP郵箱驗(yàn)證示例教程
- php郵箱地址正則表達(dá)式驗(yàn)證
- php驗(yàn)證郵箱和ip地址最簡(jiǎn)單方法匯總
- js和php郵箱地址驗(yàn)證的實(shí)現(xiàn)方法
- php使用filter過(guò)濾器驗(yàn)證郵箱 ipv6地址 url驗(yàn)證
- PHP+Ajax異步通訊實(shí)現(xiàn)用戶名郵箱驗(yàn)證是否已注冊(cè)( 2種方法實(shí)現(xiàn))
- 通過(guò)PHP實(shí)現(xiàn)用戶注冊(cè)后郵箱驗(yàn)證激活
相關(guān)文章
備份mysql數(shù)據(jù)庫(kù)的php代碼(一個(gè)表一個(gè)文件)
用php實(shí)現(xiàn)的備份MySQL數(shù)據(jù)庫(kù)的代碼,需要的朋友可以參考下。2010-05-05phpmyadmin 3.4 空密碼登錄的實(shí)現(xiàn)方法
很多時(shí)候我們?cè)诒緳C(jī)測(cè)試時(shí)會(huì)將root用戶密碼設(shè)置為空。2010-05-05header函數(shù)設(shè)置響應(yīng)頭解決php跨域問(wèn)題實(shí)例詳解
在本篇文章里小編給大家整理的是關(guān)于header函數(shù)設(shè)置響應(yīng)頭解決php跨域問(wèn)題實(shí)例內(nèi)容,有需要的朋友們可以參考下。2020-01-01CakePHP去除默認(rèn)顯示的標(biāo)題及圖標(biāo)的方法
使用cakephp框架時(shí),在生成的html頁(yè)面里,總是有cakephp的標(biāo)志(上面有大大的標(biāo)題CakePHP Rapid Development,下面還有一個(gè)cakephp的圖標(biāo)),雖然是cakephp的東西,但放到自己的項(xiàng)目中看起來(lái)總是不順眼。2008-10-10WordPress網(wǎng)站訪問(wèn)慢解決方案細(xì)圖文教程
這篇文章主要介紹了WordPress網(wǎng)站訪問(wèn)慢解決方案細(xì)圖文教程,wordpress訪問(wèn)慢一直是一個(gè)比較頭疼的問(wèn)題,有正好需要的同學(xué)可以嘗試下,感覺(jué)不錯(cuò)的可以分享給大家2021-03-03分享8個(gè)最佳的代碼片段在線測(cè)試網(wǎng)站
有時(shí)候,我們需要測(cè)試一些代碼片段,而電腦中沒(méi)有安裝針對(duì)該語(yǔ)言的運(yùn)行環(huán)境,沒(méi)關(guān)系,你可以在線測(cè)試它們2013-06-06