PHP中如何實(shí)現(xiàn)常用郵箱的基本判斷
更新時(shí)間:2014年01月07日 16:13:17 作者:
在郵件發(fā)送出去之前,用戶的基本信息已經(jīng)存在于數(shù)據(jù)庫中了,如果是個(gè)錯(cuò)誤的郵箱或者是惡意多注冊(cè)賬戶那就需要過濾了,下面為大家介紹下PHP中實(shí)現(xiàn)常用郵箱的判斷
越來越多的網(wǎng)站希望用戶使用郵箱進(jìn)行注冊(cè),或者是綁定郵箱,這時(shí)候就要對(duì)郵箱的正確性進(jìn)行確認(rèn),有的人采用發(fā)送郵件進(jìn)行激活的方式來進(jìn)行判斷,從而激活一個(gè)賬戶,但是存在一個(gè)問題就是,在郵件發(fā)送出去之前,用戶的基本信息已經(jīng)存在于數(shù)據(jù)庫中了,如果是個(gè)錯(cuò)誤的郵箱或者是惡意多注冊(cè)賬戶,那就會(huì)造成非活動(dòng)賬號(hào)太多,占用數(shù)據(jù)庫存儲(chǔ)空間,這邊就需要在之前就進(jìn)行這些郵箱的過濾,因此作者寫下下面的一個(gè)方法用來過濾郵箱。
/**
* @todo 用戶輸入安全性檢測
* @param $inputString 用戶輸入信息
* @return true/false
* @final 可以根據(jù)自己的需求進(jìn)行過濾內(nèi)容的變換
*/
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){//檢測是否存在多個(gè)@字符
return FALSE;
}else{
if (in_array('@'.$emailArr[1], Yii::app() -> params['mail_suffix'])){//檢測后綴是否滿足日常常用郵箱后綴
return TRUE;
}else{
return FALSE;
}
}
}else{
return FALSE;
}
}else{
return FALSE;
}
}
其中我定義了一個(gè)常用郵箱的后綴的數(shù)組,具體如下:
//常用郵箱后綴,根據(jù)具體需求可以再增加
'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',
),
到此郵箱的過濾方法就完成了,大家可以在此基礎(chǔ)上進(jìn)行進(jìn)一步的完善!
復(fù)制代碼 代碼如下:
/**
* @todo 用戶輸入安全性檢測
* @param $inputString 用戶輸入信息
* @return true/false
* @final 可以根據(jù)自己的需求進(jìn)行過濾內(nèi)容的變換
*/
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){//檢測是否存在多個(gè)@字符
return FALSE;
}else{
if (in_array('@'.$emailArr[1], Yii::app() -> params['mail_suffix'])){//檢測后綴是否滿足日常常用郵箱后綴
return TRUE;
}else{
return FALSE;
}
}
}else{
return FALSE;
}
}else{
return FALSE;
}
}
其中我定義了一個(gè)常用郵箱的后綴的數(shù)組,具體如下:
//常用郵箱后綴,根據(jù)具體需求可以再增加
復(fù)制代碼 代碼如下:
'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',
),
到此郵箱的過濾方法就完成了,大家可以在此基礎(chǔ)上進(jìn)行進(jìn)一步的完善!
相關(guān)文章
mysql_connect localhost和127.0.0.1的區(qū)別(網(wǎng)絡(luò)層闡述)
這篇文章主要介紹了mysql_connect localhost和127.0.0.1的區(qū)別(網(wǎng)絡(luò)層闡述),本文從網(wǎng)絡(luò)通信層面講解了它們的不同,需要的朋友可以參考下2015-03-03