標籤:名稱 定義函數 back 數字 callback 出錯 highlight san 過濾
以前用PHP驗證郵箱、URL、IP是否合法都是通過自己寫正則來實現,但是有時候腦子發昏,可能會寫出一個不是完全正確的正則,導致驗證出錯,今天發現原來PHP本身內建了驗證郵箱、URL、IP是否合法的函數。
主要使用的是filter_var函數。
文法
filter_var(variable, filter, options)
參數 描述
variable 必需。規定要過濾的變數。
filter 可選。規定要使用的過濾器的 ID。
options 規定包含標誌/選項的數組。檢查每個過濾器可能的標誌和選項。
PHP Filters
| ID 名稱 |
描述 |
| FILTER_CALLBACK |
調用使用者自訂函數來過濾資料。 |
| FILTER_SANITIZE_STRING |
去除標籤,去除或編碼特殊字元。 |
| FILTER_SANITIZE_STRIPPED |
“string” 過濾器的別名。 |
| FILTER_SANITIZE_ENCODED |
URL-encode 字串,去除或編碼特殊字元。 |
| FILTER_SANITIZE_SPECIAL_CHARS |
HTML 逸出字元 ‘”<>& 以及 ASCII 值小於 32 的字元。 |
| FILTER_SANITIZE_EMAIL |
刪除所有字元,除了字母、數字以及 !#$%&‘*+-/=?^_`{|}[email protected][] |
| FILTER_SANITIZE_URL |
刪除所有字元,除了字母、數字以及 $-_.+!*‘(),{}|\\^~[]`<>#%”;/?:@&= |
| FILTER_SANITIZE_NUMBER_INT |
刪除所有字元,除了數字和 +- |
| FILTER_SANITIZE_NUMBER_FLOAT |
刪除所有字元,除了數字、+- 以及 .,eE。 |
| FILTER_SANITIZE_MAGIC_QUOTES |
應用 addslashes()。 |
| FILTER_UNSAFE_RAW |
不進行任何過濾,去除或編碼特殊字元。 |
| FILTER_VALIDATE_INT |
在指定的範圍以整數驗證值。 |
| FILTER_VALIDATE_BOOLEAN |
如果是 “1″, “true”, “on” 以及 “yes”,則返回 true,如果是 “0″, “false”, “off”, “no” 以及 “”,則返回 false。否則返回 NULL。 |
| FILTER_VALIDATE_FLOAT |
以浮點數驗證值。 |
| FILTER_VALIDATE_REGEXP |
根據 regexp,相容 Perl 的Regex來驗證值。 |
| FILTER_VALIDATE_URL |
把值作為 URL 來驗證。 |
| FILTER_VALIDATE_EMAIL |
把值作為 e-mail 來驗證。 |
| FILTER_VALIDATE_IP |
把值作為 IP 位址來驗證。 |
Example #1 A filter_var() example
?
| 1234 |
<?phpvar_dump(filter_var(‘[email protected]‘, FILTER_VALIDATE_EMAIL));var_dump(filter_var(‘http://example.com‘, FILTER_VALIDATE_URL, FILTER_FLAG_PATH_REQUIRED));?> |
以上常式會輸出:
?
| 12 |
string(15) "[email protected]"bool(false) |
以上所述是小編給大家介紹的PHP內建方法驗證郵箱、URL、IP是否合法的函數,希望對大家有所協助,如果大家有任何疑問請給我留言,小編會及時回複大家的。在此也非常感謝大家對指令碼之家網站的支援!
原文連結:http://blog.csdn.net/veloi/article/details/53520995
php內建驗證郵箱 url ip函數