eagleshi 发表于 2015-8-25 08:04:32

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 地址来验证


页: [1]
查看完整版本: PHP filter_var() 函数