PHP filter_var() 函數


一直以來,都是用正則表達式來進行email的格式驗證,卻不知道PHP本身有內置的過濾方法,在此記錄一下,以免忘了。

W3School描述如下:

定義和用法

filter_var() 函數通過指定的過濾器過濾變量。

如果成功,則返回已過濾的數據,如果失敗,則返回 false。

語法

filter_var(variable, filter, options)
參數 描述
variable 必需。規定要過濾的變量。
filter 可選。規定要使用的過濾器的 ID。
options 規定包含標志/選項的數組。檢查每個過濾器可能的標志和選項。

提示和注釋

提示:參見完整的 PHP Filter 參考手冊,查看可與該函數一同使用的過濾器。

例子

<?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 過濾器用於對來自非安全來源的數據(比如用戶輸入)進行驗證和過濾。

安裝

filter 函數是 PHP 核心的組成部分。無需安裝即可使用這些函數。

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 地址來驗證


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM