拿郵箱驗證來說,網上絕大部分人寫的郵箱驗證正則表達式代碼都不能驗證這郵箱:
[email protected],也不能驗證 [email protected] 。
上次我發現youku.com(優酷網)用戶注冊就有這個問題,見圖:
今天發現 QQ微信 也同樣有這個問題:
他們都不能驗證一個字母的域名或一個字母的用戶名。
我認為,他們絕不是故意不讓這樣的用戶注冊,而是這樣:
很久之前,最初寫正則的程序員偷懶了,沒有寫 這樣情況的正則表達式驗證,
他當時可能覺得這樣的正則比較麻煩,而且可能這樣的郵箱實在太少了,
沒有聽說一個字母的頂級域名提供郵箱服務,也沒有見那個郵箱的用戶名是一個字母的,于是就沒寫。
而后來的程序員就一直沿用這個代碼。。。。。
-------------------
因為程序不能處理位置類型的數據,比如 2003年網絡大面積爆發 SQL 注入,就是一個經典案例。
正如比爾蓋茨前輩說:用戶的所有輸入都是有害的,程序員要盡可能的驗證所有可能性,否則,漏掉的可能性就是一個潛在的危機。
-------------------
我順便寫一個完整的郵箱驗證正則表達式吧,以后不要搞這種錯誤,讓人很郁悶。。
PHP 郵箱驗證正則表達式:
preg_match("/^[0-9a-zA-Z]+@(([0-9a-zA-Z]+)[.])+[a-z]{2,4}$/i",$email );
如果需要更加完善、嚴格的驗證,修改這個正則表達式即可。
PHP 郵箱驗證正則表達式 新手實例:
復制代碼代碼如下:
<?php
function isEmail($email){
if(preg_match("/^[0-9a-zA-Z]+@(([0-9a-zA-Z]+)[.])+[a-z]{2,4}$/i",$email )){
return '是郵箱';
} else{
return '不是郵箱';
}
}
?>
--------------------------------------------------------------------------------
Javascript(js) 郵箱驗證正則表達式:
myreg = /^([a-zA-Z0-9]+[_|/_|/.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|/_|/.]?)*[a-zA-Z0-9]+/.[a-zA-Z]{2,4}$/;
這個可以驗證 形如:
[email protected] ,
[email protected] 這種郵箱
--------------------------------------------------------------------------------
Javascript(js) 郵箱驗證正則表達式 新手實例:
復制代碼代碼如下:
<script type="text/javascript">
function isEmail(val){
var myreg = /^([a-zA-Z0-9]+[_|/_|/.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|/_|/.]?)*[a-zA-Z0-9]+/.[a-zA-Z]{2,4}$/;
if(!myreg.test(val))
return '不是郵箱';
return '是郵箱';
};
alert( isEmail('
[email protected]') );
</script>