在程序里对用户输入的邮箱、URL、IP地址进行判断时,可能你习惯了使用正则之类preg_match来进行判断,但实际PHP自带的方法filter_var就已经有了这样的功能。
filter_var()函数通过指定的过滤器过滤变量。 如果成功,则返回已过滤的数据,如果失败,则返回 false。
#filter_var使用语法
filter_var(variable, filter, options)

variable:要过滤的变量。
filter:规定要使用的过滤器的ID。
options:规定包含标志/选项的数组。不同的过滤器ID需要附加的参加,比如使用正则过滤就需要在这里添加正则表达式。

#如下为判断是否是整数,邮箱,网址
if(filter_var($age,FILTER_VALIDATE_INT)==FALSE){
    echo 'not a number';    
}
if(filter_var($email,FILTER_VALIDATE_EMAIL)==FALSE){
    echo 'not a Email';   
}
if(filter_var($website,FILTER_VALIDATE_URL)==FALSE){
    echo 'not a Website';  
}

常用的FiltersID名称及描述如下:
FILTER_VALIDATE_FLOAT:以浮点数验证值。
FILTER_VALIDATE_REGEXP:根据 regexp,兼容 Perl 的正则表达式来验证值。
FILTER_VALIDATE_URL:把值作为 URL 来验证。
FILTER_VALIDATE_EMAIL:把值作为 e-mail 来验证。
FILTER_VALIDATE_IP:把值作为 IP 地址来验证。
FILTER_VALIDATE_INT:在指定的范围以整数验证值。
FILTER_SANITIZE_NUMBER_FLOAT:删除所有字符,除了数字、+- 以及 .,

其它可用的FiltersID名称及描述如下:
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_MAGIC_QUOTES:应用 addslashes()。
FILTER_UNSAFE_RAW:不进行任何过滤,去除或编码特殊字符。
FILTER_VALIDATE_BOOLEAN:如果是 "1", "true", "on" 以及 "yes",则返回 true,如果是 "0", "false", "off", "no" 以及 "",则返回 false。否则返回 NULL。

相关评论(0)
您是不是忘了说点什么?

友情提示:垃圾评论一律封号...

还没有评论,快来抢沙发吧!