一直以來,都是用正則表達式來進行email的格式驗證,卻不知道PHP本身有內置的過濾方法,在此記錄一下,以免忘了。
W3School描述如下:
定義和用法
filter_var() 函數通過指定的過濾器過濾變量。
如果成功,則返回已過濾的數據,如果失敗,則返回 false。
語法
filter_var(variable, filter, options)
| 參數 | 描述 |
|---|---|
| variable | 必需。規定要過濾的變量。 |
| filter | 可選。規定要使用的過濾器的 ID。 |
| options | 規定包含標志/選項的數組。檢查每個過濾器可能的標志和選項。 |
例子
<?php
if(!filter_var("someone@example....com", FILTER_VALIDATE_EMAIL))
{
echo("E-mail is not valid");
}
else
{
echo("E-mail is valid");
}
?>
輸出類似:
E-mail is not valid
PHP Filter 函數
PHP:指示支持該函數的最早的 PHP 版本。
| 函數 | 描述 | PHP |
|---|---|---|
| filter_has_var() | 檢查是否存在指定輸入類型的變量。 | 5 |
| filter_id() | 返回指定過濾器的 ID 號。 | 5 |
| filter_input() | 從腳本外部獲取輸入,並進行過濾。 | 5 |
| filter_input_array() | 從腳本外部獲取多項輸入,並進行過濾。 | 5 |
| filter_list() | 返回包含所有得到支持的過濾器的一個數組。 | 5 |
| filter_var_array() | 獲取多項變量,並進行過濾。 | 5 |
| filter_var() | 獲取一個變量,並進行過濾。 | 5 |
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 | 刪除所有字符,除了字母、數字以及 !#$%&'*+-/=?^_`{|}~@.[] |
| 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 的正則表達式來驗證值。 |
| FILTER_VALIDATE_URL | 把值作為 URL 來驗證。 |
| FILTER_VALIDATE_EMAIL | 把值作為 e-mail 來驗證。 |
| FILTER_VALIDATE_IP | 把值作為 IP 地址來驗證 |
