越來越多的網站希望使用者使用郵箱進行註冊,或者是綁定郵箱,這時候就要對郵箱的正確性進行確認,有的人採用發送郵件進行啟用的方式來進行判斷,從而啟用一個賬戶,但是存在一個問題就是,在郵件發送出去之前,使用者的基本資料已經存在於資料庫中了,如果是個錯誤的郵箱或者是惡意多註冊賬戶,那就會造成非活動帳號太多,佔用資料庫儲存空間,這邊就需要在之前就進行這些郵箱的過濾,因此作者寫下下面的一個方法用來過濾郵箱。
複製代碼 代碼如下:
/**
* @todo 使用者輸入安全性檢測
* @param $inputString 使用者輸入資訊
* @return true/false
* @final 可以根據自己的需求進行過濾內容的變換
*/
public function checkUserInput($inputString){
if (strpos('script', $inputString)!=false){//檢測是否含有script指令碼
return FALSE;
}else if (strpos('iframe', $inputString)!=false){//檢測是否含有iframe架構
return FALSE;
}else {
return TRUE;
}
}
/**
* @todo checkeemail
* @param emailString
* @return false/true
*/
public function checkEmail($emailString){
if ($this -> checkUserInput($emailString) === TRUE){//檢測是否含有禁用語
if (strpos('@', $emailString) != FALSE){//檢測是否存在@字元
$emailArr = explode('@', $emailString);
if (count($emailArr) > 2){//檢測是否存在多個@字元
return FALSE;
}else{
if (in_array('@'.$emailArr[1], Yii::app() -> params['mail_suffix'])){//檢測尾碼是否滿足日常常用郵箱尾碼
return TRUE;
}else{
return FALSE;
}
}
}else{
return FALSE;
}
}else{
return FALSE;
}
}
其中我定義了一個常用郵箱的尾碼的數組,具體如下:
//常用郵箱尾碼,根據具體需求可以再增加
複製代碼 代碼如下:
'mail_suffix'=>array('@hotmail.com',
'@msn.com',
'@yahoo.com',
'@gmail.com',
'@aim.com',
'@aol.com',
'@mail.com',
'@walla.com',
'@inbox.com',
'@126.com',
'@163.com',
'@sina.com',
'@21cn.com',
'@sohu.com',
'@yahoo.com.cn',
'@tom.com',
'@qq.com',
'@etang.com',
'@eyou.com',
'@56.com',
'@x.cn',
'@chinaren.com',
'@sogou.com',
'@citiz.com',
),
到此郵箱的過濾方法就完成了,大家可以在此基礎上進行進一步的完善!