1. 程式人生 > >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 名稱 描述
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 的正則表示式來驗證值。
FILTER_VALIDATE_URL 把值作為 URL 來驗證。
FILTER_VALIDATE_EMAIL 把值作為 e-mail 來驗證。
FILTER_VALIDATE_IP 把值作為 IP 地址來驗證。

Example #1 A filter_var() example

1

2

3

4

<?php

var_dump(filter_var('[email protected]', FILTER_VALIDATE_EMAIL));

var_dump(filter_var('http://example.com', FILTER_VALIDATE_URL, FILTER_FLAG_PATH_REQUIRED));

?>

以上例程會輸出:

string(15) "[email protected]"
bool(false)