PHP自帶方法驗證郵箱、URL、IP是否合法
PHP驗證郵箱、URL、IP是否合法
以前用PHP驗證郵箱、URL、IP是否合法都是通過自己寫正則來實現,但是有時候腦子發昏,可能會寫出一個不是完全正確的正則,導致驗證出錯,今天發現原來PHP本身自帶了驗證郵箱、URL、IP是否合法的函數。
主要使用的是filter_var函數。
語法
filter_var(variable, filter, options)
參數 描述
variable 必需。規定要過濾的變量。
filter 可選。規定要使用的過濾器的 ID。
options 規定包含標志/選項的數組。檢查每個過濾器可能的標志和選項。
PHP Filters
ID 名稱 | 描述 | </tr>|||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
FILTER_CALLBACK | 調用用戶自定義函數來過濾數據。 | </tr>|||||||||||||||||||||||||
FILTER_SANITIZE_STRING | 去除標簽,去除或編碼特殊字符。 | </tr>|||||||||||||||||||||||||
FILTER_SANITIZE_STRIPPED | “string” 過濾器的別名。 | </tr>|||||||||||||||||||||||||
FILTER_SANITIZE_ENCODED | URL-encode 字符串,去除或編碼特殊字符。 | </tr>|||||||||||||||||||||||||
FILTER_SANITIZE_SPECIAL_CHARS | HTML 轉義字符 ‘”<>& 以及 ASCII 值小于 32 的字符。 | </tr>|||||||||||||||||||||||||
FILTER_SANITIZE_EMAIL | 刪除所有字符,除了字母、數字以及 !#$%&’*+-/=?^_`{|}~@.[] | </tr>|||||||||||||||||||||||||
FILTER_SANITIZE_URL | 刪除所有字符,除了字母、數字以及 $-_.+!*’(),{}|\\^~[]`<>#%”;/?:@&= | </tr>|||||||||||||||||||||||||
FILTER_SANITIZE_NUMBER_INT | 刪除所有字符,除了數字和 +- | </tr>|||||||||||||||||||||||||
FILTER_SANITIZE_NUMBER_FLOAT | 刪除所有字符,除了數字、+- 以及 .,eE。 | </tr>|||||||||||||||||||||||||
FILTER_SANITIZE_MAGIC_QUOTES | 應用 addslashes()。 | </tr>|||||||||||||||||||||||||
FILTER_UNSAFE_RAW | 不進行任何過濾,去除或編碼特殊字符。 | </tr>|||||||||||||||||||||||||
FILTER_VALIDATE_INT | 在指定的范圍以整數驗證值。 | </tr>|||||||||||||||||||||||||
FILTER_VALIDATE_BOOLEAN | 如果是 “1″, “true”, “on” 以及 “yes”,則返回 true,如果是 “0″, “false”, “off”, “no” 以及 “”,則返回 false。否則返回 NULL。 | </tr>|||||||||||||||||||||||||
FILTER_VALIDATE_FLOAT | 以浮點數驗證值。 | </tr>|||||||||||||||||||||||||
FILTER_VALIDATE_REGEXP | 根據 regexp,兼容 Perl 的正則表達式來驗證值。 | </tr>|||||||||||||||||||||||||
FILTER_VALIDATE_URL | 把值作為 URL 來驗證。 | </tr>|||||||||||||||||||||||||
FILTER_VALIDATE_EMAIL | 把值作為 e-mail 來驗證。 | </tr>|||||||||||||||||||||||||
FILTER_VALIDATE_IP | 把值作為 IP 地址來驗證。 | </tr> </tbody> </table>